gpt4 book ai didi

javascript - 下拉菜单以记住选择并重定向用户

转载 作者:行者123 更新时间:2023-11-30 05:52:27 25 4
gpt4 key购买 nike

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

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>

谢谢!院长

最佳答案

我同意 yckart's comment并建议使用 localStorage。

支持非常好 (shown here),除非您需要支持 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/

关于javascript - 下拉菜单以记住选择并重定向用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13886793/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com