62

我可以在不丢失任何表单数据的情况下重新加载当前页面吗?我用了..

window.location = window.location.href;

window.location.reload(true);

但这两个东西无法为我获取更早的表单数据。怎么了 ?手动刷新浏览器时,很好(我不会丢失任何表单数据)。请指导我如何弄清楚。

这是我的完整代码...

<div class="form-actions">
        <form>
            <table cellpadding = "5" cellspacing ="10">
                <tr class="control-group">
                    <td style="width: 100px;">
                        <div>Name:&nbsp;<font color="red">(*)</font></div>
                    </td>
                    <td>
                        <input type="text" id="inputName" placeholder="Name" required>
                    </td>
                </tr>
                <tr class="control-group">
                    <td>
                        <div>Email:&nbsp;<font color="red">(*)</font></div>
                    </td>
                    <td>
                        <input class="span3" placeholder="user@gmail.com" id= "inputEmail" type="email" required>
                    </td>
                </tr>
                <tr class="control-group">
                    <td>
                        <div>Phone:&nbsp;</div>
                    </td>
                    <td>
                        <input type="text" id="inputPhone" placeholder="phone number">
                    </td>
                </tr>
                <tr class="control-group">
                    <td>
                        <div>Subject:&nbsp;<font color="red">(*)</font></div>
                    </td>
                    <td>
                        <input type="text" id="inputSubject" placeholder="Subject" required>
                    </td>
                </tr>
                <tr class="control-group">
                    <td colspan ="2">
                        <div>
                            <div>Detail:&nbsp;</div>
                            <div class="controls">
                                <textarea id="inputDetail"></textarea>
                            </div>
                    </td>
                </tr>
                <tr>
                    <td colspan="2">
                    <div>
                        <label style="font-weight: bold;" class="checkbox"> <input id="confirmCheck" value="" type="checkbox">
                                I Agree to the Personal information handling policy
                        </label>
                    </div>
                    <div id = "alert_placeholder"></div>
                        <div class="acceptment">
                            [Personal information handling policy]<br> <br>
                        </div>
                    </td>
                </tr>
                <tr>
                    <td colspan="2">
                        <div align="center">
                            <button id="btnConfirm" class="btn btn-primary">Confirm</button>
                            <input type="reset" style="width: 65px; height: 27px;" id="btnReset" class="btn">
                        </div>
                    </td>
                </tr>
            </table>
        </form>
    </div>

在我的 JS 文件中..

function bind() {
$('#btnConfirm').click(function(e) {
    if ($('#confirmCheck').is(":checked")) {
        getConfirmationForSendFAQ();
    }
    else {
        e.preventDefault();
        showalert("You should accept \"Personal Information Policy\" !", "alert-error");
    }
});};function getConfirmationForSendFAQ() {
    var name = $('#inputName').val();
    var email = $('#inputEmail').val();
    var phone = $('#inputPhone').val();
    var subject = $('#inputSubject').val();
    var detail = $('#inputDetail').val();

    $('.form-actions').empty();
    html = [];
    html.push("<table cellpadding ='8' class = 'submitInfo'");
    html.push("<tr>");
    html.push("<td class = 'title'>Name:</div>");
    html.push("<td class = 'value'>"+ name +"</td>");
    html.push("</tr>");

    html.push("<tr>");
    html.push("<td class = 'title'>Email Address:</div>");
    html.push("<td class = 'value'>"+ email +"</td>");
    html.push("</tr>");

    if (phone.trim().length > 0) {
        html.push("<tr>");
        html.push("<td class = 'title'>Phone No:</div>");
        html.push("<td class = 'value'>"+ phone +"</td>");
        html.push("</tr>");
    }

    html.push("<tr>");
    html.push("<td class = 'title'>Subject:</div>");
    html.push("<td class = 'value'>"+ subject +"</td>");
    html.push("</tr>");

    html.push("<tr>");
    html.push("<td class = 'title'>Detail Info:</div>");
    html.push("<td class = 'value'>"+ detail +"</td>");
    html.push("</tr>");

    html.push("<tr>");
    html.push("<td colspan='2'><div align = 'center'>");
    html.push("<button id='btnSend' class='btn btn-primary' style='width: 65px;'>Send</button>");
    html.push("<button id='btnReturn' class='btn btn-inverse' style='width: 65px; height: 27px; margin-left: 5px;'>Return</button>");
    html.push("</div></td></tr>");

    html.push("</table>");
    $('.form-actions').append(html.join(''));
    $('#btnReturn').click(function(e) {
        // HERE I WANT TO KNOW HOW TO DO.....
    });
    $('#btnSend').click(function(e) {
        alert("Doom");
    });}
4

14 回答 14

71

您可以使用各种本地存储机制将这些数据存储在浏览器中,例如 Web Storage、IndexedDB、WebSQL(已弃用)和 File API(已弃用且仅在 Chrome 中可用)(以及带有 IE 的 UserData)。

最简单和最广泛支持的是 WebStorage,其中您有持久存储 ( localStorage) 或基于会话的 ( sessionStorage),它在内存中直到您关闭浏览器。两者共享相同的 API。

例如,当页面即将重新加载时,您可以(简化)执行以下操作:

window.onbeforeunload = function() {
    localStorage.setItem("name", $('#inputName').val());
    localStorage.setItem("email", $('#inputEmail').val());
    localStorage.setItem("phone", $('#inputPhone').val());
    localStorage.setItem("subject", $('#inputSubject').val());
    localStorage.setItem("detail", $('#inputDetail').val());
    // ...
}

网络存储同步工作,所以这可能在这里工作。或者,您可以将每个模糊事件的数据存储在输入数据的元素上。

在页面加载时,您可以检查:

window.onload = function() {

    var name = localStorage.getItem("name");
    if (name !== null) $('#inputName').val("name");

    // ...
}

getItemnull如果数据不存在则返回。

如果您只想临时存储,请使用sessionStorage而不是。localStorage

于 2013-07-11T11:15:09.803 回答
26

我修改了 K3N 的代码以达到我的目的,并添加了一些注释以帮助其他人弄清楚 sessionStorage 是如何工作的。

<script>
    // Run on page load
    window.onload = function() {

        // If sessionStorage is storing default values (ex. name), exit the function and do not restore data
        if (sessionStorage.getItem('name') == "name") {
            return;
        }

        // If values are not blank, restore them to the fields
        var name = sessionStorage.getItem('name');
        if (name !== null) $('#inputName').val(name);

        var email = sessionStorage.getItem('email');
        if (email !== null) $('#inputEmail').val(email);

        var subject= sessionStorage.getItem('subject');
        if (subject!== null) $('#inputSubject').val(subject);

        var message= sessionStorage.getItem('message');
        if (message!== null) $('#inputMessage').val(message);
    }

    // Before refreshing the page, save the form data to sessionStorage
    window.onbeforeunload = function() {
        sessionStorage.setItem("name", $('#inputName').val());
        sessionStorage.setItem("email", $('#inputEmail').val());
        sessionStorage.setItem("subject", $('#inputSubject').val());
        sessionStorage.setItem("message", $('#inputMessage').val());
    }
</script>
于 2015-09-29T00:38:25.477 回答
7

在 GitHub 上找到这个。专门为它打造的。

https://gist.github.com/zaus/4717416

于 2013-11-12T09:16:39.570 回答
6

这个答案对我非常有帮助,并且省去了手动浏览每个字段的麻烦:

使用jQuery存储复杂表单的状态

于 2014-06-14T20:10:25.660 回答
6
window.location.reload() // without passing true as argument

为我工作。

于 2015-09-24T12:00:39.017 回答
4

正如一些答案所提到的,localStorage是一个不错的选择,您当然可以自己做,但是如果您正在寻找一个完美的选择,GitHub 上已经有一个项目可以做到这一点,称为garlic.js

于 2015-09-29T00:49:46.160 回答
3

我通常会自动将我自己的表单提交到服务器并重新加载带有填充参数的页面。将占位符参数替换为您的服务器收到的参数。

于 2013-07-11T11:06:50.107 回答
3

同意 HTML5 LocaStorage。 这是示例代码

于 2013-07-11T11:10:55.533 回答
2

您必须提交数据并重新加载页面(带有数据的服务器端呈现表单),只是重新加载不会保留数据。只是您的浏览器可能会在手动刷新时缓存表单数据(跨浏览器不一样)。

于 2013-07-11T11:00:24.350 回答
2

您可以使用 localStorage ( http://www.w3schools.com/html/html5_webstorage.asp ) 在刷新页面之前保存值。

于 2013-07-11T11:02:12.140 回答
2

您可以使用我编写的库FormPersistence.js,它通过将值保存到本地/会话存储来处理表单(反)序列化。这种方法类似于另一个答案中链接的方法,但它不需要 jQuery,也不会将明文密码保存到网络存储中。

let myForm = document.getElementById('my-form')
FormPersistence.persist(myForm, true)

每个FormPersistence函数的可选第二个参数定义是使用本地存储 ( false) 还是会话存储 ( true)。在您的情况下,会话存储可能更合适。

默认情况下,表单数据将在提交时从存储中清除,除非您false作为第三个参数传递。如果您有特殊的值处理功能(例如插入元素),那么您可以将它们作为第四个参数传递。有关完整文档,请参阅存储库。

于 2019-01-07T23:01:45.173 回答
1

一个简单而通用的(无 jquery)解决方案,用于所有输入(类型文本)字段,取消本地存储。

function save_data(){
    let fields = document.querySelectorAll("input[type='text']")
    let saved_fields = []
    fields.forEach(x => {
        saved_fields.push({
            key: x.id,
            value: x.value
        })
    })
    localStorage.setItem("saved_data", JSON.stringify(saved_fields))
 }

 function show_saved_data(){
     JSON.parse(localStorage.getItem("saved_data")).forEach(x => {
         document.getElementById(x.key).value = x.value
     })
 }

如果要包含“选择/复选框”字段等,则必须在 for 循环中添加一些 if else 逻辑并更改查询....

于 2021-07-06T13:44:02.870 回答
1

使用 $_POST 本身:

<?php           
isset($_POST['value']) ? $value= $_POST['value'] : $value= NULL;
echo '<form method="POST">';
echo '<input type="text" name="value" value="'.$value.'"/>';
echo '<input type="submit" name="submit" value="Submit"/>';
echo '</form>';
?>
于 2021-09-26T23:43:17.737 回答
0

为事件注册一个事件监听器keyup

document.getElementById("input").addEventListener("keyup", function(e){
  var someVarName = input.value;
  sessionStorage.setItem("someVarKey", someVarName);
  input.value = sessionStorage.getItem("someVarKey");
});
于 2019-05-09T10:15:39.123 回答