0
私はCDNリソースを実装しようとしましたローカルフォールバック私のウェブページのサポート。 しかし、私はjqueryとBootstrapのレンダリングをブロックするJavaScriptとCSSのCDNリソースを "fold-above-fold"のコンテンツで取り除くことはできません。Google PageSpeed Insight CSS Javascript「折りたたみの上」問題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 ">
UPDATE:私の.js CDNスクリプトを読み込むために "async/defer"属性を使用しようとしました。しかし、私のローカルフォールバックスクリプトが私に"Uncaught ReferenceError:$が定義されていません"というメッセージが表示されるので、動作しませんでした。エラーは、jquery非同期ロードが完了する前に実行されるためです。 jQueryライブラリーを使用し
閉鎖ボディタグの直前に配置してください( '