0
我試圖實施CDN資源本地回退支持我的網頁。 但現在我無法擺脫「摺疊式」內容中的jquery和Bootstrap的呈現阻止JavaScript和CSS CDN資源。Google PageSpeed Insight CSS使用CDN的「摺疊之上」問題
我試圖堅持谷歌的指引但它並沒有解決我的問題:
<html>
<head>
</head>
<body>
<div id="wrapper">...</div>
<!-- jQuery CDN -->
<script src="https://code.jquery.com/jquery-2.2.2.min.js"></script>
<!-- jQuery local fallback -->
<script>
window.jQuery || document.write('<script src="./assets/scripts/jquery-2.2.2.min.js"><\/script>')
</script>
<!-- Bootstrap JS CDN -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js</script>
<!-- Bootstrap JS local fallback -->
<script>if(typeof($.fn.modal) === 'undefined') {document.write('<script src="./assets/scripts/bootstrap.min.js"><\/script>')}</script>
<!-- Bootstrap CSS local fallback -->
<div id="bootstrapCssTest " class="hide "></div>
<script>
$(document).ready(function() {
if ($('#bootstrapCssTest').is(':visible') === true) {
$("head ").append('<link rel="stylesheet " href="./assets/styles/bootstrap.min.css">');
}
});
</script>
</body>
</html>
<!-- Bootstrap CSS CDN -->
<link rel="stylesheet " href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css ">
更新:我試圖使用「async/defer」屬性來加載我的.js CDN腳本。但它不工作,因爲我的本地回退腳本給我「未捕獲ReferenceError:$未定義」錯誤,因爲它們在jquery異步加載完成之前執行。
將它們放在結束體標籤之前('