1. 盤點JavaScript 事件和方法提交那些事兒

        共 3918字,需瀏覽 8分鐘

         ·

        2024-06-25 10:00

        點擊上方“前端進階學習交流”,進行關注

        回復“前端”即可獲贈前端相關學習資料

        紛紛暮雪下轅門,風掣紅旗凍不翻。

        大家好,我進階學習者。

        一、前言

        提交表單時,會觸發(fā) submit 事件,它通常用于在將表單發(fā)送到服務器之前對表單進行校驗,或者中止提交,并使用 JavaScript 來處理表單。

        form.submit() 方法允許從 JavaScript 啟動表單發(fā)送??梢允褂么朔椒▌討B(tài)地創(chuàng)建表單,并將其發(fā)送到服務器。


        二、事件:submit

        1. 提交表單主要有兩種方式。

        第一種 :

        點擊 <input type="submit"><input type="image">,

        第二種 :在 input 字段中按下 Enter 鍵。

        這兩個行為都會觸發(fā)表單的 submit 事件。

        處理程序可以檢查數(shù)據(jù),如果有錯誤,就顯示出來,并調用 event.preventDefault(),這樣表單就不會被發(fā)送到服務器了。

        案例:

        在文本字段中按下 Enter 鍵。點擊 <input type="submit">。

        這兩種行為都會顯示 alert,而因為代碼中的 return false,表單不會被發(fā)送到別處。        

        <form onsubmit="alert('submit!');return false">            First: Enter in the input field         <input type="text" value="text"><br>            Second: Click "submit": <input type="submit" value="Submit">        </form>

        2. submit 和 click 的關系

        在輸入框中使用 Enter 發(fā)送表單時,會在 <input type="submit"> 上觸發(fā)一次 click 事件。

        這很有趣,因為實際上根本沒有點擊。

        例 :

        <form onsubmit="return false"> <input type="text" size="30" value="Focus here and press enter"> <input type="submit" value="Submit" onclick="alert('click')"></form>


        三、方法:submit

        如果要手動將表單提交到服務器,可以調用 form.submit()。

        這樣就不會產生 submit 事件。這里假設如果開發(fā)人員調用 form.submit(),就意味著此腳本已經(jīng)進行了所有相關處理。

        有時該方法被用來手動創(chuàng)建和發(fā)送表單,如下所示:      

        <script>            let form = document.createElement('form');            form.action = 'https://google.com/search';            form.method = 'GET';            form.innerHTML = '<input name="q" value="test">';            // 該表單必須在文檔中才能提交            document.body.append(form);            form.submit();</script>

        運行結果:

        重置表單

        為< input >或< button >標簽設置type=“reset"屬性可以定義重置按鈕。

        <inpu type="reset" value="重置"><button type="reset">重置</button>

        當單擊重置按鈕時,表單將被重置,所有表單字段恢復為初始值。這是會觸發(fā)reset事件。1

        例:單擊【重置】按鈕,彈出提示,恢復文本框默認值。

        <!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>    </head>    <body>        <form id="form1" name="form1" method="post" action="">            <input type="text" name="t" id="t" />            <input type="reset"  name="重置"/>        </form>        <script>            var t = document.getElementsByTagName("input")[0];            var f = document.getElementById("form1");            f.onreset = function(e){                alert(t.value);            }</script>    </body></html>

        運行結果:

        注:

        在提交表單禁用提交按鈕的時候,應該在“submit”事件添加事件處理函數(shù)。不要用click。

        因為不同的瀏覽器存在時差,有的瀏覽器會在觸發(fā)表單的submit事件之前觸發(fā)click事件,有的在這之后。


        四、總結

        本文基于JavaScript基礎,介紹了 事件和方法提交, submit 和 click 的關系對比。通過案例的分析,在實際應用需要注意的點,遇到的問題,提供有效的解決方案。

        歡迎大家積極嘗試,有時候看到別人實現(xiàn)起來很簡單,但是到自己動手實現(xiàn)的時候,總會有各種各樣的問題,切勿眼高手低,勤動手,才可以理解的更加深刻。

        代碼很簡單,希望對你學習有幫助。

        ------------------- End -------------------

        往期精彩文章推薦:

        歡迎大家點贊,留言,轉發(fā),轉載,感謝大家的相伴與支持

        想加入前端學習群請在后臺回復【入群

        萬水千山總是情,點個【在看】行不行

        瀏覽 28
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
          
          

            1. 国产极品美女在线精品 | 西西444WWW无码大胆图 | 韩日在线 | 韩国黄色免费 | 黄片靠逼 |