ホームページ >ウェブフロントエンド >jsチュートリアル >CSS がロードされた後に後続のコードを実行するかどうかを決定します。

CSS がロードされた後に後続のコードを実行するかどうかを決定します。

WBOY
WBOYオリジナル
2016-05-16 16:37:301440ブラウズ

現在、プロジェクトフレームワークを作成し、jquery uiでdialog()を使用してメッセージボックスを表示するJQueryMessageBoxクラスを作成しています。メソッドを呼び出しやすくするために、ページが追加されたかどうかの自動判定を追加しました。 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 コードはすぐにはロードされないため、ダイアログが表示されるときにスタイルはありません (これは IE9 では問題ありません。IE9 では、CSS が後でダウンロードされたとしてもページ要素は再描画されるため、この問題を解決するには、CSS が読み込まれた後、ダイアログが表示されます。コードは次のとおりです。

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 までご連絡ください。