0

H5BP は、(onload リスナーを使用して) ウィンドウが完全にロードされたときにのみ実行されるように、JavaScript および jQuery コードを作成することを想定していますか? 私が尋ねる理由は、H5BP が以下に示すように body タグの下部にある jQuery 包含スクリプト タグを見つけるためです。ただし、Cookie が設定されているスクリプトは、jquery.min.js スクリプト要素を body の前にある head 要素に移動しない限り機能しません (したがって、Cookie スクリプトの実行)。ありがとう。

<!DOCTYPE html>
    <head>
        <meta charset="utf-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
        <title></title>
        <meta name="description" content="">
        <meta name="viewport" content="width=device-width">
        <script src="js/vendor/modernizr-2.6.2.min.js"></script>
    </head>
    <body>
        <p>This is HTML5 Boilerplate.</p>

        <!-- Cookie isn't set when jquery.min.js follows this element block  -->
        <script>
            var test_profile = { browserWidth: $(window).width() };
            document.cookie = "test_profile=" + JSON.stringify(test_profile);
        </script>

        <script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
        <script>window.jQuery || document.write('<script src="js/vendor/jquery-1.9.1.min.js"><\/script>')</script>
    </body>
</html>
4

1 に答える 1

0

最初の<script>ブロックは jQuery ( ) に依存して$(window).width()いるため、jQuery がロードされる前に使用することはできません。

その Cookie スクリプトを他の 2 つの<script>ブロックの後に移動するだけです。

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script>window.jQuery || document.write('<script src="js/vendor/jquery-1.9.1.min.js"><\/script>')</script>

<script>
    var test_profile = { browserWidth: $(window).width() };
    document.cookie = "test_profile=" + JSON.stringify(test_profile);
</script>
于 2013-06-12T20:57:17.893 に答える