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异步加载完成之前执行。
将它们放在结束体标签之前('