手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >判断在css加载完毕后执行后续代码示例
判断在css加载完毕后执行后续代码示例
摘要:最近在写项目的framework,写个JQueryMessageBox的类,以使用jqueryui中的dialog()来显示消息框,为了使方...

最近在写项目的framework,写个JQueryMessageBox的类,以使用jquery ui中的dialog()来显示消息框,为了使方法方便调用,便加入了自动判断页面是否加入了ui.js和ui.css,代码如下:

//如果没有包含ui.js,则引用 if ($('script[src$=""jquery-ui-1.8.11.custom.min.js""]').length == 0) {{ $(""<script src='http://www.jb51.netjs/jquery-ui-1.8.11.custom.min.js' type='text/javascript' />"").appendTo('head'); }} //如果没有加载css,则加载 if ($('link[ref$=""jquery-ui-1.8.14.custom.css""]').length == 0) {{ $('<link href=""/css/jquery-ui-1.8.14.custom.css"" rel=""stylesheet"" type=""text/css"" />').appendTo('head'); //dialog() script }}

但CSS代码不会立即加载下来,于是在显示dialog的时候则不会有样式(在IE9下可以,因为在IE9下CSS即使后下载下来,也会重新绘制页面元素,而IE8则不会).解决此问题的方法,可以使用ajax,当css加载完毕后,再显示dialog,这样就可以带着样式显示出来了,代码如下:

if ($('link[ref$=""jquery-ui-1.8.14.custom.css""]').length == 0) { $.ajax({ url: '/css/jquery-ui-1.8.14.custom.css', success: function(data) { //创建一个style元素,并追加到head中 //替换其中images的路径 $('<style type="text/css">' + data.replace(/url(images/g, 'url(/css/images') + '</style>').appendTo('head'); //dialog() script; } }); } else { //dialog() script; }

【判断在css加载完毕后执行后续代码示例】相关文章:

JavaScript判断图片是否已经加载完毕的方法汇总

图片加载进度实时显示

游戏人文件夹程序 ver 3.0

广告显示判断

AspNet中使用JQuery上传插件Uploadify详解

JQuery勾选指定name的复选框集合并显示的方法

黑色风格的JS日历代码,左右箭头翻页年、月

判断是否输入完毕再激活提交按钮

在HTML中插入JavaScript代码的示例

打印/预览/设置的客户端代码

精品推荐
分类导航