2

我正在制作一个带有下拉菜单的登录页面,它将用户重定向到一个新目录。

http://steerbox.com/countryselect/

该部分正在工作,现在我需要添加代码以在选择国家/地区时设置 cookie,以便下次用户访问登录页面时,他们将自动被重定向到该国家/地区的目录,而无需从下拉菜单中进行选择再次。

我发现 jquery 和 javascript 会在选择下拉菜单时设置 cookie,但我似乎无法让下拉菜单既设置 cookie 又重定向用户。以下是我当前用于下拉和重定向的脚本:

<Script language="JavaScript">
function goto(form) { var index=form.select.selectedIndex
if (form.select.options[index].value != "0") {
location=form.select.options[index].value;}}
</SCRIPT>
<FORM NAME="form1">
<SELECT NAME="select" ONCHANGE="goto(this.form)" SIZE="1">
<OPTION VALUE="">Select Country
<OPTION VALUE="chile">Chile
<OPTION VALUE="colombia">Colombia
<OPTION VALUE="bolivia">Bolivia
</select>
</FORM>

谢谢!院长

4

1 回答 1

3

我同意yckart 的评论并建议使用 localStorage。

支持非常好(此处显示),除非您需要支持 IE7 或更低版本,否则应该没问题。

您可以像这样设置和检索数据:

localStorage.varName = 'bling';
var myVal = localStorage.varName;
// or:
localStorage['a little more flexibility'] = 'bling';

要使用它,您可以执行以下操作:

<script type="text/javascript">
    if (localStorage && localStorage.country) {
        location = localStorage.country;    
    }

    function formChanged(form) {
        var val = form.options[form.selectedIndex].value;
        if (val !== 'non-value') {
          if (localStorage) {
            localStorage.country = val;
          }
          location = val;
        }
    }
</script>

<FORM NAME="form1">
  <select onchange="formChanged(this);" NAME="country" SIZE="1">
    <OPTION VALUE="non-value">Select Country
    <OPTION VALUE="chile">Chile
    <OPTION VALUE="colombia">Colombia
    <OPTION VALUE="bolivia">Bolivia
  </select>
</FORM>

http://jsfiddle.net/K4Jkc/

一种更保守的方法是在进行重定向之前将存储在 localStorage(如果有的话)中的值与选择列表中的选项进行比较,如下面的 jsFiddle 所示:

http://jsfiddle.net/K4Jkc/1/

于 2012-12-15T06:50:17.870 回答