为了缩短这个简短,我有一排复选框,我试图让它在单击一个选项时保存并保留浏览器重新加载。
我将数组输出到本地存储中,但是它没有保存,到目前为止这是代码:
<section class="column">
<label><input type="checkbox" name="BBCNews" class="checked" v-model="isBBCNews"><span>BBC News</span></label>
<label><input type="checkbox" name="BBCSport" class="checked" v-model="isBBCSport"><span>BBC Sport</span></label>
<label><input type="checkbox" name="TheTelegraph" class="checked" v-model="isTheTelegraph"><span>The Telegraph</span></label>
<label><input type="checkbox" name="TheIndependent" class="checked" v-model="isTheIndependent"><span>The Independent</span></label>
</section>
<section class="column">
<label><input type="checkbox" name="LadBible" class="checked" v-model="isLadBible"><span>Lad Bible</span></label>
<label><input type="checkbox" name="HackerNews" class="checked" v-model="isHackerNews"><span>Hacker News</span></label>
<label><input type="checkbox" name="Reddit" class="checked" v-model="isReddit"><span>Reddit</span></label>
<label><input type="checkbox" name="ProductHunt" class="checked" v-model="isProductHunt"><span>Product Hunt</span></label>
</section>
这是当前的javascript代码
// Store services to local
var enabledServices = JSON.parse(localStorage.getItem('enabledServices')) || {},
$checkboxes = $("input[type='checkbox']");
$checkboxes.on("change", function(){
$checkboxes.each(function(){
enabledServices[this.name] = this.checked;
});
localStorage.setItem("enabledServices", JSON.stringify(enabledServices));
});
// On page load
$.each(enabledServices, function(key, value) {
$("#" + key).prop('checked', value);
});
这是显示在本地存储screenshot
中的数组我希望选项完全消失,但是一个简单的错误就行了,目前当我刷新所有复选框时会回到当前状态。
感谢任何帮助。
修改
通过对{Vue https://www.npmjs.com/package/vue-persist使用Vue Persist
包,我实现了我所需要的。
答案 0 :(得分:1)
从您的代码中没有id
分配给复选框,因此以下内容将失败:
$("#" + key).prop('checked', value);
您写给localstorage
key
的是名字。更改为以下内容以按名称获取复选框并更新checked
属性。
$("[name='" + key + "']").prop('checked', value);
// Store services to local
var enabledServices = JSON.parse(localStorage.getItem('enabledServices')) || {},
$checkboxes = $("input[type='checkbox']");
$checkboxes.on("change", function () {
$checkboxes.each(function () {
enabledServices[this.name] = this.checked;
});
localStorage.setItem("enabledServices", JSON.stringify(enabledServices));
});
// On page load
$.each(enabledServices, function (key, value) {
$("[name='" + key + "']").prop('checked', value);
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<section class="column">
<label><input type="checkbox" name="BBCNews" class="checked" v-model="isBBCNews"><span>BBC News</span></label>
<label><input type="checkbox" name="BBCSport" class="checked" v-model="isBBCSport"><span>BBC Sport</span></label>
<label><input type="checkbox" name="TheTelegraph" class="checked" v-model="isTheTelegraph"><span>The Telegraph</span></label>
<label><input type="checkbox" name="TheIndependent" class="checked" v-model="isTheIndependent"><span>The Independent</span></label>
</section>
<section class="column">
<label><input type="checkbox" name="LadBible" class="checked" v-model="isLadBible"><span>Lad Bible</span></label>
<label><input type="checkbox" name="HackerNews" class="checked" v-model="isHackerNews"><span>Hacker News</span></label>
<label><input type="checkbox" name="Reddit" class="checked" v-model="isReddit"><span>Reddit</span></label>
<label><input type="checkbox" name="ProductHunt" class="checked" v-model="isProductHunt"><span>Product Hunt</span></label>
</section>
&#13;