正如标题所暗示的,这在 Chrome 之外的任何地方都有效,如果可能的话,我想修复它。用户可以从下拉框中选择一种颜色,并将其保存在 cookie 中,以供下次加载。但在 Chrome 中,下拉框不起作用。代码通过了验证器文本。
无论如何,如果你能提供帮助,那就太好了。
<html>
<head>
<meta http-equiv="Content-Language" content=en-us>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title>Background Color selection</title>
</head>
<body>
<form onsubmit="return false;" action="">
<p><select name="color_select" size="1" onchange="return setColor(this, global_name)">
<option style="background-color: aliceblue;" value="aliceblue">aliceblue (#F0F8FF)</option>
<option style="background-color: antiquewhite;" value="antiquewhite">antiquewhite (#FAEBD7)</option>
<option style="background-color: aqua;" value="aqua">aqua (#00FFFF)</option>
<option style="background-color: aquamarine;" value="aquamarine">aquamarine (#7FFFD4)</option>
<option style="background-color: azure;" value="azure">azure (#F0FFFF)</option>
<option style="background-color: beige;" value="beige">beige (#F5F5DC)</option>
</select>
<input type="button" value="Delete Cookie"
onclick="delCookie(global_name); return getColor(color_select, global_name)"></p>
</form>
<script type="text/javascript">
<!--//
var global_name = 'color';
//
function getColor(sel, cookie_name) {
var cookie_value = getCookie(cookie_name);
if (!cookie_value) cookie_value = 'white';
document.body.style.backgroundColor = cookie_value;
var opt = sel.options;
var x, len = sel.length;
for (x=0; x<len; x++) {
if (opt[x].value == cookie_value) {
opt[x].selected = true;
break;
}
}
return true;
}
getColor(document.forms[0].color_select, global_name);
//
function setColor(sel, cookie_name) {
var opt = sel.options[sel.selectedIndex].value;
var oneDay = 24 * 60 * 60 * 1000;
var oneYear = 365 * oneDay;
var expDate = new Date();
expDate.setTime(expDate.getTime() + oneYear);
setCookie(cookie_name, opt, expDate);
return getColor(sel, cookie_name);
}
// ---------------------------------------- //
function getCookie(name) {
var arg = name + "=";
var alen = arg.length;
var clen = document.cookie.length;
var i = 0;
while (i < clen) {
var j = i + alen;
if (document.cookie.substring(i, j) == arg)
return getCookieVal (j);
i = document.cookie.indexOf(" ", i) + 1;
if (i == 0) break;
}
return null;
}
function getCookieVal(offset) {
var endstr = document.cookie.indexOf (";", offset);
if (endstr == -1)
endstr = document.cookie.length;
return unescape(document.cookie.substring(offset, endstr));
}
function setCookie(name, value) {
var argv = setCookie.arguments;
var argc = setCookie.arguments.length;
var expires = (argc > 2) ? argv[2] : null;
var path = (argc > 3) ? argv[3] : null;
var domain = (argc > 4) ? argv[4] : null;
var secure = (argc > 5) ? argv[5] : false;
document.cookie = name + "=" + escape (value) +
((expires == null) ? "" : ("; expires=" + expires.toGMTString())) +
((path == null) ? "" : ("; path=" + path)) +
((domain == null) ? "" : ("; domain=" + domain)) +
((secure == true) ? "; secure" : "");
}
function delCookie(name) {
exp = new Date();
exp.setTime(exp.getTime() - (24*60*60*1000));
var cval = getCookie(name);
cval = (cval == null) ? "" : cval;
document.cookie = name + "=" + cval + "; expires=" + exp.toGMTString();
}
//-->
</script>
</body>
</html>