2012-04-11 71 views
1

我一直在使用演示网站,因为昨天,并在我自己的网站上做了一个版本。jQuery cookie读取/写入表单

这里是演示网站: http://rikrikrik.com/jquery/autosave/

这里是确切的代码是在我的网站: http://jsfiddle.net/EswfB/1/

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

它有时有效,有时不起作用。通常只有当我点击它时才会起作用,刷新,点击恢复并再次点击删除。

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

使用Chrome和FF。

任何想法?

单击删除相关cookie时,地址栏不会显示href =“#”的标志。同时删除相关的cookies不做任何事。

回答

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>​ 
+0

我的知识不伸展,远远此刻所以它会像我重新开始了。我有这个广告正在运行,昨天它正在工作,我需要的只是修复了有关删除相关cookie的html href类以及即时消息。我感谢你的建议。 – 2012-04-11 11:22:42

+1

等一下,我几乎完成了你的整个代码;) – Dion 2012-04-11 11:44:29

+0

谢谢,我耐心等待:)请注意 - 出于某种原因,有时jsFiddle代码无法正常工作,但我只有一个问题,那就是删除相关的cookies不起作用。实际的保存和恢复呢! – 2012-04-11 11:47:35