zoukankan      html  css  js  c++  java
  • 在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.         $(""<script src='/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.         $('<link href=""/css/jquery-ui-1.8.14.custom.css"" rel=""stylesheet"" type=""text/css"" />').appendTo('head');  
    8.   
    9. //dialog() script  
    10.     }}  

    但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.                         $('<style type="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.             }  
  • 相关阅读:
    JavaWeb03-4.0.0版本的pom.xml
    Git学习(上)
    JavaWeb02-如何创建一个基础的Maven项目
    JavaWeb01-maven环境搭建
    HTML5学习
    RSA和AES加密解密过程
    mysql安装失败,最后一步无响应
    powerDesign16通过PLSql中导出的建表语句,建立E-R图
    PLSQL developer+instantclient_11_2实现远程连接Oracle数据库
    分享黄维仁博士关于亲密关系的佳言
  • 原文地址:https://www.cnblogs.com/ranzige/p/3937669.html
Copyright © 2011-2022 走看看