jQuery cookie读/写表单

时间:2012-04-11 10:59:09

标签: php jquery html forms cookies

我从昨天开始就使用了一个演示网站,并在我自己的网站上制作了一个版本。

以下是演示网站: http://rikrikrik.com/jquery/autosave/

以下是我网站上的确切代码: http://jsfiddle.net/EswfB/1/

问题: 删除相关的cookie无法正常工作。

它有时有效,有时则无效。通常只有在我点击它,刷新,点击恢复并再次点击删除时才能工作。

现在,演示网站和我的网站昨天工作正常,关闭我的机器,今天返回,但都没有工作。也不要在我的同事机器上工作。

使用Chrome和FF。

有什么想法吗?

点击删除相关的Cookie时,地址栏没有显示href =“#”的迹象。删除相关的cookie也无效。

1 个答案:

答案 0 :(得分:2)

我建议在JavaScript中使用localStorage,这很容易管理。你会节省很多代码。 http://jsfiddle.net/EswfB/8/

function save() {
    var firstname = document.profileForm.First_name.value;
    var lastname = document.profileForm.Last_name.value;
    if(document.getElementById("GenderMale").checked) {
        var gender = "Male";
    }
    else if(document.getElementById("GenderFemale").checked) {
        var gender = "Female";
    }
    var howdowecontactyou = document.profileForm.How_do_we_contact_you.value;
    var preferredtimeofcontact = document.profileForm.Preferred_time_of_contact.value;
    var jobtitle = document.profileForm.Job_title.value;
    localStorage.setItem("firstname", firstname);
    localStorage.setItem("lastname", lastname);
    localStorage.setItem("gender", gender);
    localStorage.setItem("howdowecontactyou", howdowecontactyou);
    localStorage.setItem("preferredtimeofcontact", preferredtimeofcontact);
    localStorage.setItem("jobtitle", jobtitle);
    document.getElementById("autosave_saving").innerHTML = "Saved!";
}
function load() {
    var firstname =  localStorage.getItem("firstname");
    var lastname =  localStorage.getItem("lastname");
    var gender =  localStorage.getItem("gender");
    var howdowecontactyou =  localStorage.getItem("howdowecontactyou");
    var preferredtimeofcontact =  localStorage.getItem("preferredtimeofcontact");
    var jobtitle =  localStorage.getItem("jobtitle");
    document.profileForm.First_name.value = firstname;
    document.profileForm.Last_name.value = lastname;
    if(gender == "Male") {
        document.getElementById("GenderMale").checked = true;
        document.getElementById("GenderFemale").checked = false;
    }
    if(gender == "Female") {
        document.getElementById("GenderMale").checked = false;
        document.getElementById("GenderFemale").checked = true;
    }
    document.profileForm.How_do_we_contact_you.value = howdowecontactyou;
    document.profileForm.Preferred_time_of_contact.value = preferredtimeofcontact
    document.profileForm.Job_title.value = jobtitle;
}
function deleteStorage() {
    localStorage.removeItem("firstname");
    localStorage.removeItem("lastname");
    localStorage.removeItem("gender");
    localStorage.removeItem("howdowecontactyou");
    localStorage.removeItem("preferredtimeofcontact");
    localStorage.removeItem("jobtitle");
}
​

和HTML:

<p><button class="autosave" OnClick="save()">Save form</button> <button class="autosave_restore" OnClick="load()">Restore form</button> <input type="RESET" value="Default Form"> <button OnClick="deleteStorage()" class="autosave_removecookies">Delete related cookies</button> <span class="autosave_saving" id="autosave_saving"></span></p>
<!-- Licensed software, from www.freecontactform.com -->
<form name="profileForm" accept-charset="utf-8" method="post" action="forms/simple_form/_process.php" onSubmit="return validate.check(this)">
<table class="widthOneHundredPercent">
<tr>
<td class="tableCellFloat widthFortyPercent" valign="top">
<label for="First_name" class="required">First name<span class="required_star"> * </span></label>
</td>
<td class="tableCellFloat" valign="top">
<input type="text" name="First_name" id="First_name" maxlength="50" value="" placeholder="First name"/>
</td>
</tr>
<tr>
<td class="tableCellFloat widthFortyPercent" valign="top">
<label for="Last_name" class="required">Last name<span class="required_star"> * </span></label>
</td>
<td class="tableCellFloat" valign="top">
<input type="text" name="Last_name" id="Last_name" maxlength="50" value="" placeholder="Last name"/>
</td>
</tr>
<tr>
<td class="tableCellFloat columnOne" valign="top">
<label for="Gender">Gender</label></td>
</td>
<td class="tableCellFloat columnTwo" valign="top">
<input type="radio" name="Gender" value="Male" id="GenderMale" />Male<br />
<input type="radio" name="Gender" value="Female" id="GenderFemale" />Female<br />
</td>
</tr>
<tr>
<td class="tableCellFloat widthFortyPercent" valign="top">
<label for="How_do_we_contact_you?" class="required">How do we contact you?<span class="required_star"> * </span></label>
</td>
<td class="tableCellFloat" valign="top">
<select class="tableCellFloat" id="How_do_we_contact_you" name="How_do_we_contact_you">
<option value="">Please select...</option>
<option value="Email">Email</option>
<option value="Phone">Phone</option>
<option value="Text">Text</option>
</select>
</td>
</tr>
<tr>
<td class="tableCellFloat widthFortyPercent" valign="top">
<label for="Preferred_time_of_contact">Preferred time of contact?</label>
</td>
<td class="tableCellFloat" valign="top">
<select class="tableCellFloat" id="Preferred_time_of_contact" name="Preferred_time_of_contact">
<option value="">Please select...</option>
<option value="08:00_-_12:00">08:00 - 12:00</option>
<option value="12:00_-_17:30">12:00 - 17:30</option>
<option value="17:30_-_20:00">17:30 - 20:00</option>
<option value="Anytime">Anytime</option>
</select>
</td>
</tr>
<tr>
<td class="tableCellFloat widthFortyPercent" valign="top">
<label for="Job_title">Job title</label>
</td>
<td class="tableCellFloat" valign="top">
<input type="text" name="Job_title" id="Job_title" maxlength="50" value="" placeholder="Job title"/>
</td>
</tr>
</table>    
<div class="clearboth">&nbsp;</div>
<center><input type="SUBMIT" value="submit"></center>
</form>​