0

タイトルが示すように、これは Chrome を除くすべての場所で機能します。可能であれば修正したいと思います。ユーザーはドロップダウン ボックスから色を選択でき、次の読み込みのために Cookie に保存されます。しかし、Chrome ではドロップダウン ボックスが機能しません。コードは Validator テキストを渡しました。

とにかく、あなたが助けることができれば、それは素晴らしいことです.

      <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>&nbsp;
    <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>
4

1 に答える 1

3

Germán Enríquez の jsfiddleで示されているように、コードは Google Chrome で動作します (少なくともバージョン 24.0 ベータ版)。

私は2つのことを提案することができます:

  1. chrome://extensions/ に移動して、Google Chrome の拡張機能を無効にします。そのうちの 1 つが何らかの形で干渉している可能性があります。
  2. chrome://settings/content に移動し、Cookie が無効になっている場合は有効にします。

また、コードが検証に合格したとおっしゃいました。まず、HTML ページには doctype が必要です。ここで自分で試すことができます: http://validator.w3.org/#validate_by_input

また、 http: //www.jslint.com/ で JavaScript コードを lint してみてください。コードに多くの問題が見つかることに驚かれることでしょう。たとえばvar argv = setCookie.arguments;、関数の引数にアクセスする最良の方法ではなく、厳密モードでは確実に壊れます。また、ステートメントは変数をグローバルスコープにexp = new Date();リークします。exp

これで問題が解決しない場合は、問題の詳細をお知らせください。それに応じて回答いたします。

アップデート

コメントで、HTML をファイルにコピーしてブラウザで開いていると言及していたことに気付きました。でファイルにアクセスしていますfile://か? もしそうなら、それが Chrome が問題を引き起こしている理由かもしれません。実際、Google Chrome:

...さまざまな理由で、file://のCookieを意図的に無効にします...

これは、2008 年以降の Chrome の WontFix issue 535 です。http://code.google.com/p/chromium/issues/detail?id=535 を参照してください。

ローカルサーバーを実行して、http://localhost/または経由でファイルを開いてみてくださいhttp://127.0.0.1/

于 2012-12-09T15:50:59.563 に答える