我有一个html表和一个Javascript代码,通过按“添加新表”按钮在其下添加一个新表。问题是,当我刷新页面时,刚刚添加的表格消失了。当我刷新页面时,如何在添加后保留它?
<table border="0" style="margin: auto; ">
<td width="60%" >
<fieldset style="width:530px; padding-left:5px; background-color:white " >
<INPUT type="button" value="Add new Table" onclick="addRow('dataTable')" />
School/University/College*</br>
<input name="school_1" type="text" size="73"/>
</br></br>
Field of Study</br>
<input name="field_1" type="text" size="73"/>
</br></br>
Specialized subjects</br>
<input name="specialized_subject_1" type="text" size="73" />
</br></br>
Degree</br>
<input name="degree_1" type="text" size="73"/>
</br></br>
Grade</br>
<input name="grade_1" type="text" size="73" />
</br></br></br>
Attended from: <select name="month_1_1">
<option value=" "> EMPTY </option>
<option value="January">January</option>
</select>
<select id="year_1_1" name="year_1_1">
<option value=" "> EMPTY </option>
<option value="2009">2009</option>
</select>
Until: <select name="month_1_2">
<option value=" "> EMPTY </option>
<option value="January">January</option>
</select>
<select name="year_1_2">
<option value=" "> EMPTY </option>
<option value="2009">2009</option>
</select>
</h2></font>
</fieldset>
</td>
</table>
这是Javascript代码:
<SCRIPT language="javascript">
function addRow(tableID) {
var table = document.getElementById(tableID);
var rowCount = table.rows.length;
var row = table.insertRow(rowCount);
var colCount = table.rows[0].cells.length;
for(var i=0; i<colCount; i++) {
var newcell = row.insertCell(i);
newcell.innerHTML = table.rows[0].cells[i].innerHTML;
//alert(newcell.childNodes);
switch(newcell.childNodes[0].type) {
case "text":
newcell.childNodes[0].value = "";
break;
case "select-one":
newcell.childNodes[0].selectedIndex = 0;
break;
}
}
}
</SCRIPT>
答案 0 :(得分:1)
JavaScript不会写入该文件。因此,只有当您在页面上时才能进行更改。我不希望用户能够直接编辑HTML文件。
如果您需要它们来保留并且更改是针对特定用户的,则可以保存它们的选项(即添加的表的数量),并在页面为时使服务器端(PHP或w / e)添加表服务了。
答案 1 :(得分:1)
问题是刷新基本上是从头开始询问页面,因此服务器正在向客户端提供页面,好像它是一个新请求。
这就是为什么你需要在某个地方保存页面状态(或者至少是用户数据),有多种方法可以做到这一点,使用viewstate是一个或者一个会话变量是另一个。
当你加载页面时,首先要做的是将信息加载回存储的页面(在视图状态或会话中) - 参见ASP.NET或其他等效技术。
如果您无法维护页面的“状态”(即您没有运行Web应用程序,您只是使用一些javascript来提供HTML页面),那么您需要确保用户无法刷新页面或弹出一些东西提醒他们他们的偏好没有存储(无论哪种方式使用都有点不友好)。