本地存储循环

时间:2013-01-10 11:03:54

标签: javascript jquery local-storage

我正在尝试在我的网站上运行一些本地存储,我正在努力。

我有几个“切换滑块”(例如:http://jquerymobile.com/test/docs/forms/switch/#),我想将用户选择保存到本地存储,这样当用户返回时,他们仍然可以看到他们之前的选择。

我已经让它适用于列表中的第一个切换滑块但是我想要做的是遍历每个滑块并为每个滑块,将其“id”和“value”保存到本地存储。然后,一旦保存,在页面加载时,恢复它们并根据它在本地存储中的内容改变切换开关。

这是我的代码:

//code below saves id and value to local storage when save button is clicked
$("#button").click(function() {
    window.localStorage.setItem('flip-min-1', $("#flip-min-1").val());
});

好的,以便工作和本地存储我得到以下内容:

Key: #flip-min-1    Value: yes or no depending on choice as it is a toggle slider

现在,当浏览器关闭并重新打开时,我会从本地存储中检索数据并使用它根据所说内容切换滑块:

var storedText = window.localStorage.getItem('flip-min-1');

//if the variable in local storage is equal to yes
if(storedText = 'yes') {
    //then switch the toggle slider to the yes state so it appear in red and reads 'Attending'
    $("#flip-min-1").val(window.localStorage.getItem('flip-min-1')).keyup();
    //if the stored text is anything other than yes, the default select option will be no. By default the user is not attending any events
}

我正在努力的是,我有多个切换开关,并且我需要在本地存储中保存其ID和值!

我真的需要帮助,如果有人愿意提出他们的时间我会很高兴,提前谢谢,汤姆

1 个答案:

答案 0 :(得分:0)

如果您有一定数量的开关,只需将所有内容放入for循环中,例如

for(var i = 0; i < 5; i++) {
    $("#button" + i).click(function() {
        window.localStorage.setItem('flip-min-' + i, $("#flip-min-" + i).val());
    });
}

否则,您可以为所有人提供类和数据属性,例如:

<button class="mySwitch" data-number="1">Switch 1</button>
<button class="mySwitch" data-number="2">Switch 2</button>

并使用这样的代码

// find all switches
$(".mySwitch")
// handle click event and save
.click(function() {
  var index = $(this).attr("data-number");
  window.localStorage.setItem('flip-min-' + index, $("#flip-min-" + index).val());
});
// load all states
.each(function() {
  var index = $(this).attr("data-number");
  var storedText = window.localStorage.getItem('flip-min-' + index);

  //if the variable in local storage is equal to yes
  if(storedText = 'yes') {
      //then switch the toggle slider to the yes state so it appear in red and reads 'Attending'
      $("#flip-min-1").val(window.localStorage.getItem('flip-min-' + index)).keyup();
      //if the stored text is anything other than yes, the default select option will be no. By default the user is not attending any events
  }
});