H5BP是否假设您将编写JavaScript和jQuery代码,以便仅在窗口完全加载(使用onload侦听器)时执行?我问的原因是H5BP在body标签的底部找到了jQuery包含脚本标签,如下所示。但是,除非我将jquery.min.js脚本元素移动到正文之前的head元素(因此执行cookie脚本),否则设置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>
答案 0 :(得分:0)
第一个<script>
块依赖于jQuery($(window).width()
),因此在加载jQuery之前无法使用它。
只需在其他两个<script>
块之后移动该Cookie脚本:
<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>