在css加载完毕后自动判断页面是否加入css或js文件
2014-09-10 17:17
573 查看
最近在写项目的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='/js/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加载完毕后自动判断页面是否加入css或js文件
- js如何判断引入的js文件是否加载完毕
- js判断flash文件是否加载完毕
- 页面加入_JS,CSS使用,#include添加文件,缓存页面,页面间传递汉字,IsPostBack控制页面的加载,自定义错语页面
- js判断页面是否加载完毕
- js判断页面是否加载完毕
- Js判断CSS文件加载完毕的具体实现
- 判断CSS与JS是否加载完毕的方法
- Wordpress不同页面判断加载头部JS CSS等文件
- Js判断CSS文件加载完毕的实例教程
- Js判断CSS文件加载完毕的具体实现
- JS加载js文件或css文件和判断是否加载该js或css
- js判断页面是否加载完毕
- js判断页面是否加载完毕
- 用js判断页面是否加载完毕
- js判断页面是否加载完毕
- 判断一个页面是否加载了某个js文件
- js 页面加载完成后判断表单元素是否存在
- Delphi中WebBrowser判断页面及JS是否加载完成
- asp.net在使用母版页的内容页面中动态加载css和js文件的方法