V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
simadad
V2EX  ›  问与答

AJAX 提交表单,页面为什么会刷新?

  •  
  •   simadad · 2018-10-16 11:26:16 +08:00 · 2144 次点击
    这是一个创建于 2260 天前的主题,其中的信息可能已经有所发展或是发生改变。

    AJAX 提交表单,页面为什么会刷新?

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>TTT</title>
    </head>
    <body>
        <form id="f" method="get">
            <input type="text" placeholder="A">
            <button type="submit">B</button>
        </form>
        <script>
        document.getElementById('f').onsubmit = function (e) {
            console.log(e);
            const xhr = new XMLHttpRequest();
            xhr.open('get', '', true);
            xhr.send();
        };
        </script>
    </body>
    </html>
    

    上面这段简短的代码,点击按钮,预期应该是在 console 里打印出提交事件,然后页面不刷新,结果 TM 每次点击按钮整个页面都刷新一次————

    已尝试方法

    onsubmit 函数最后加上 return false 可以做到异步提交,不刷新网页。

    但是

    但是,我很确定我以前实现的异步提交从来都没用过 return false,不知道为什么这次突然就不行了,有没有大神能够回答?

    附上之前没加 return false 仍然成功的代码————

    function post_tab() {
            // 提交标签打印数量
            document.getElementById('work_form').onsubmit = function (e) {
                e.preventDefault();
                const xhr = new XMLHttpRequest(),
                    f = e.target,
                    formData = new FormData(f),
                    log = $('#print_log');
                xhr.open('POST', f.action, true);
                xhr.responseType = 'json';
                xhr.onreadystatechange = function () {
                    if(xhr.readyState === 4 && xhr.status === 200){
                        const data = xhr.response;
                        console.log(data);
                        print_tab(data['qrs'], log[0]);
                        log.scrollTop(log[0].scrollHeight - log.height());
                        input_clean('input_qr');
                    }
                };
                xhr.send(formData);
            }
        }
    

    该函数 post_tab 使用 onclick 绑定在提交按钮上————

    <button class="btn btn-success form-control" onclick="post_tab()">开始打印</button>
    

    为什么这段代码每加 return false 仍然能够异步提交不刷新网页呢?

    5 条回复    2018-10-16 13:46:27 +08:00
    CoderEQ
        1
    CoderEQ  
       2018-10-16 11:39:10 +08:00
    第一段代码有<button type="submit">B</button> type 属性表示属于 form 表单元素。第二段<button class="btn btn-success form-control" onclick="post_tab()">开始打印</button> 仅仅是一个 button,跟 form 无关,所以不触发
    no502zhang
        2
    no502zhang  
       2018-10-16 11:41:11 +08:00
    form 中的 button 为 submit, 默认就会提交 form
    form 的 action 不写, 默认就是当前页
    simadad
        3
    simadad  
    OP
       2018-10-16 13:29:33 +08:00
    @CoderEQ 第二段省略了 `type`,chrome 的缺省值就是 submit,我刚刚测试了一下,把第二段的 `type="submit"` 加上,仍然不触发
    iNaru
        4
    iNaru  
       2018-10-16 13:39:37 +08:00   ❤️ 1
    e.preventDefault();
    阻止了浏览器的提交这个默认行为
    simadad
        5
    simadad  
    OP
       2018-10-16 13:46:27 +08:00
    @iNaru 原来如此,感谢大佬!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2586 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 15:35 · PVG 23:35 · LAX 07:35 · JFK 10:35
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.