首页 > 网站 > WEB开发 > 正文

在css加载完毕后执行后续代码

2024-04-27 14:19:49
字体:
来源:转载
供稿:网友

CSS加载完毕后执行后续代码

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

[javascript]view plaincopyPRint?
  1. //如果没有包含ui.js,则引用
  2. if($('script[src$=""jquery-ui-1.8.11.custom.min.js""]').length==0){{
  3. $(""<scriptsrc='/js/jquery-ui-1.8.11.custom.min.js'type='text/Javascript'/>"").appendTo('head');
  4. }}
  5. //如果没有加载css,则加载
  6. if($('link[ref$=""jquery-ui-1.8.14.custom.css""]').length==0){{
  7. $('<linkhref=""/css/jquery-ui-1.8.14.custom.css""rel=""stylesheet""type=""text/css""/>').appendTo('head');
  8. //dialog()script
  9. }}

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

[javascript]view plaincopyprint?
  1. if($('link[ref$=""jquery-ui-1.8.14.custom.css""]').length==0){
  2. $.ajax({
  3. url:'/css/jquery-ui-1.8.14.custom.css',
  4. success:function(data){
  5. //创建一个style元素,并追加到head中
  6. //替换其中images的路径
  7. $('<styletype="text/css">'+data.replace(/url/(images/g,'url(/css/images')+'</style>').appendTo('head');
  8. //dialog()script;
  9. }
  10. });
  11. }
  12. else{
  13. //dialog()script;
  14. }

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表