试图通过多种方式解决这个问题。1.通过简单地将普通的html“选中”默认选项添加到我的表单中的单选按钮和2.让js函数做到这一点,这是尝试过的想法的要点。
问题:我发现无论我怎么做,如果默认情况下将收音机指定为选中(在用户做出选择之前),那么之后所做的任何事情都不会正确保存(如果有的话)本地存储。localStorage 将保存最初的默认选择,但是,从那时起就无法更改任何内容(即使在“物理”选择另一个选项之后)。
我知道 localStorage 正在工作,因为如果我不使用默认名称(以及其他输入),它会完美运行。
表格代码:
<label>Who is the contact person for this event?<span class="requiredtext">*</span></label>
<input type="radio" name="Contact_Person" id="Contact_Person1" value="Submitter is the contact person" onclick="contacthide()" checked required> I am<br />
<input type="radio" name="Contact_Person" id="Contact_Person2" value="Submitter is not the contact person" onclick="contactshow()" required>
localStorage 保存代码:
function localStoragefunctions() {
localStorage.clear();
if (Modernizr.localstorage) {
//Set variable to show that data is saved
localStorage.setItem("flag", "set");
//Save radio and checkbox data
$(window).bind('unload', function() {
$('input[type=radio]').each(function() {
localStorage.setItem('radio_' + $(this).attr('id'), JSON.stringify({
checked: this.checked
}));
});
});
如果用户在最终提交之前返回进行更改,则将其吐出的代码:
$(document).ready(function() {
if (Modernizr.localstorage) {
//Browser supports it
if (localStorage.getItem("flag") == "set") {
$('input[type=radio]').each(function() {
var state = JSON.parse(localStorage.getItem('radio_' + $(this).attr('id')));
if (state) this.checked = state.checked;
});
除此之外,我有一个确认页面,它获取存储在 localStorage 中的所有变量,并将它们呈现给用户进行最终检查,然后再点击提交。
这包括: var ContactPerson = localStorage.getItem('Contact_Person');
然后是document.write
吐出html和变量值的a。同样,如果我不尝试设置默认单选选项(并且适用于所有其他输入类型),这会很好。
理想的结果是默认选择最有可能的单选按钮选项,以便可能节省用户时间。如果我可以事先“为他们做出决定”,我不想向他们展示他们必须物理单击每个单选按钮的表格。
希望这一切都有意义!