在css加载完毕后自动判断页面是否加入css或js文件
最近在写项目的framework,写个JQueryMessageBox的类,以使用jqueryui中的dialog()来显示消息框,为了使方法方便调用,便加入了自动判断页面是否加入了ui.js和ui.css,代码如下:
//如果没有包含ui.js,则引用
if($('script[src$=""jquery-ui-1.8.11.custom.min.js""]').length==0){{
$(""<scriptsrc='/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){{
$('<linkhref=""/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的路径
$('<styletype="text/css">'+data.replace(/url\(images/g,'url(/css/images')+'</style>').appendTo('head');
//dialog()script;
}
});
}
else{
//dialog()script;
}热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短