常见问题当前位置:鸿宇娱乐 > 常见问题 > >

鸿宇娱乐:在css加载完毕后自动判断页面是否加

  

鸿宇娱乐平台[css加载,执行代码]在css加载完毕后自动判断页面是否加入css或js文件

  

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

  
  
  //如果没有包含ui.js,则引用  if ($('script[src$=""jquery-ui-1.8.11.custom.min.js""]').length == 0) {{  $("""").appendTo('head');  }}  //如果没有加载css,则加载  if ($('link[ref$=""jquery-ui-1.8.14.custom.css""]').length == 0) {{  $('').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的路径  $('').appendTo('head');  //dialog() script;  }  });  }  else {  //dialog() script;  }
  

(责任编辑:admin)

上一篇:鸿宇娱乐:JQuery中属性过滤选择器用法实例分析

下一篇:extjs每个组件要设置唯一的ID否则会出错

推荐内容

客户服务热线

010-400-12345

在线客服