如何重新加载当前页面而不丢失任何表单数据?

Cat*_*ysm 54 html javascript jquery html5 jquery-ui

我可以重新加载当前页面而不会丢失任何表单数据吗?我用了..

window.location = window.location.href;
Run Code Online (Sandbox Code Playgroud)

window.location.reload(true);
Run Code Online (Sandbox Code Playgroud)

但这两件事对我来说无法获得更早的数据.怎么了 ?手动刷新浏览器时,它很好(我不会丢失任何表单数据).请指导我如何弄明白.

这是我的完整代码......

<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>
Run Code Online (Sandbox Code Playgroud)

在我的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");
    });}
Run Code Online (Sandbox Code Playgroud)

小智 55

您可以使用各种本地存储机制将此数据存储在浏览器中,例如Web存储,IndexedDB,WebSQL(不建议使用)和文件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());
    // ...
}
Run Code Online (Sandbox Code Playgroud)

Web存储同步工作,因此这可能在这里工作.(可选)您可以将每个模糊事件的数据存储在输入数据的元素上.

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

window.onload = function() {

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

    // ...
}
Run Code Online (Sandbox Code Playgroud)

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

使用sessionStorage的,而不是localStorage如果你想存储只是暂时的.

  • 这对我有用,非常感谢。但我需要更正你的答案:1) localStorage.setItem('name', ... 2) if (name !== null) $('#inputName').val('name'); =&gt; 没有引号这个解决方案对我不起作用。我通过 WebStorage 上的官方指南更正了它。 (2认同)
  • 我不喜欢的一件事是:你怎么知道什么时候清理存储?第一个想法是清除表单提交,但假设数据被提交到存储然后用户决定他们不想提交这些数据。现在它们永久地处于损坏状态,直到它们的 localStorage 被清除(或表单提交) (2认同)

Dou*_*elm 21

我修改了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>
Run Code Online (Sandbox Code Playgroud)

  • 很好的主意!**NB**sessionStorage在会话结束时被清除,而localStorage被无限期保留.在考虑数据隐私时需要考虑的事情. (5认同)

Raj*_*wal 7

在GitHub上找到这个.专门为它创建.

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


Jul*_*n K 6

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

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


Nav*_*wal 5

window.location.reload() // without passing true as argument
Run Code Online (Sandbox Code Playgroud)

为我工作。