首頁  >  文章  >  web前端  >  判斷在css載入完畢後執行後續程式碼範例_javascript技巧

判斷在css載入完畢後執行後續程式碼範例_javascript技巧

WBOY
WBOY原創
2016-05-16 16:37:301424瀏覽

最近在寫專案的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; 
}
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn