Ich habe versucht, CDN Ressourcen mit lokalen Fallback Unterstützung für meine Webseite zu implementieren. Aber jetzt kann ich nicht rendern blockierende JavaScript und CSS CDN-Ressourcen für jquery und Bootstrap in den "over-the-Fold" Inhalt loswerden.Google PageSpeed Insight CSS Javascript "über die Falte" Problem mit CDN
Ich versuchte Googles Richtlinien zu halten aber es hat mein Problem nicht lösen:
<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: Ich habe versucht, das "async/defer" -Attribut zum Laden meiner .js CDN-Skripte zu verwenden. Aber es hat nicht funktioniert, da mein lokales Fallback-Skript mir "Uncaught ReferenceError: $ ist nicht definiert" Fehler, weil sie ausgeführt werden, bevor jQuery asynchronen Laden beendet wurde.
platzieren Sie sie kurz vor dem schließenden body tag ('