• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    JavaScript操作表單_動力節點Java學院整理

    來源:懂視網 責編:小采 時間:2020-11-27 22:51:35
    文檔

    JavaScript操作表單_動力節點Java學院整理

    JavaScript操作表單_動力節點Java學院整理:用JavaScript操作表單和操作DOM是類似的,因為表單本身也是DOM樹。 不過表單的輸入框、下拉框等可以接收用戶輸入,所以用JavaScript來操作表單,可以獲得用戶輸入的內容,或者對一個輸入框設置新的內容。 HTML表單的輸入控件主要有以下幾種: ᠊
    推薦度:
    導讀JavaScript操作表單_動力節點Java學院整理:用JavaScript操作表單和操作DOM是類似的,因為表單本身也是DOM樹。 不過表單的輸入框、下拉框等可以接收用戶輸入,所以用JavaScript來操作表單,可以獲得用戶輸入的內容,或者對一個輸入框設置新的內容。 HTML表單的輸入控件主要有以下幾種: ᠊

    用JavaScript操作表單和操作DOM是類似的,因為表單本身也是DOM樹。

    不過表單的輸入框、下拉框等可以接收用戶輸入,所以用JavaScript來操作表單,可以獲得用戶輸入的內容,或者對一個輸入框設置新的內容。

    HTML表單的輸入控件主要有以下幾種:

  • 文本框,對應的<input type="text">,用于輸入文本;
  • 口令框,對應的<input type="password">,用于輸入口令;
  • 單選框,對應的<input type="radio">,用于選擇一項;
  • 復選框,對應的<input type="checkbox">,用于選擇多項;
  • 下拉框,對應的<select>,用于選擇一項;
  • 隱藏文本,對應的<input type="hidden">,用戶不可見,但表單提交時會把隱藏文本發送到服務器。
  • 獲取值

    如果我們獲得了一個<input>節點的引用,就可以直接調用value獲得對應的用戶輸入值:

    // <input type="text" id="email">
    var input = document.getElementById('email');
    input.value; // '用戶輸入的值'

    這種方式可以應用于text、password、hidden以及select。但是,對于單選框和復選框,value屬性返回的永遠是HTML預設的值,而我們需要獲得的實際是用戶是否“勾上了”選項,所以應該用checked判斷:

    // <label><input type="radio" name="weekday" id="monday" value="1"> Monday</label>
    // <label><input type="radio" name="weekday" id="tuesday" value="2"> Tuesday</label>
    var mon = document.getElementById('monday');
    var tue = document.getElementById('tuesday');
    mon.value; // '1'
    tue.value; // '2'
    mon.checked; // true或者false
    tue.checked; // true或者false

    設置值

    設置值和獲取值類似,對于text、password、hidden以及select,直接設置value就可以:

    // <input type="text" id="email">
    var input = document.getElementById('email');
    input.value = 'test@example.com'; // 文本框的內容已更新

    對于單選框和復選框,設置checked為true或false即可。

    HTML5控件

    HTML5新增了大量標準控件,常用的包括date、datetime、datetime-local、color等,它們都使用<input>標簽:

    <input type="date" value="2015-07-01">
    <input type="datetime-local" value="2015-07-01T02:03:04">
    <input type="color" value="#ff0000">

    不支持HTML5的瀏覽器無法識別新的控件,會把它們當做type="text"來顯示。支持HTML5的瀏覽器將獲得格式化的字符串。例如,type="date"類型的input的value將保證是一個有效的YYYY-MM-DD格式的日期,或者空字符串。

    提交表單

    最后,JavaScript可以以兩種方式來處理表單的提交(AJAX方式在后面介紹)。

    方式一是通過<form>元素的submit()方法提交一個表單,例如,響應一個<button>的click事件,在JavaScript代碼中提交表單:

    <!-- HTML -->
    <form id="test-form">
     <input type="text" name="test">
     <button type="button" onclick="doSubmitForm()">Submit</button>
    </form>
    <script>
    function doSubmitForm() {
     var form = document.getElementById('test-form');
     // 可以在此修改form的input...
     // 提交form:
     form.submit();
    }
    </script>

    這種方式的缺點是擾亂了瀏覽器對form的正常提交。瀏覽器默認點擊<button type="submit">時提交表單,或者用戶在最后一個輸入框按回車鍵。因此,第二種方式是響應<form>本身的onsubmit事件,在提交form時作修改:

    <!-- HTML -->
    <form id="test-form" onsubmit="return checkForm()">
     <input type="text" name="test">
     <button type="submit">Submit</button>
    </form>
    <script>
    function checkForm() {
     var form = document.getElementById('test-form');
     // 可以在此修改form的input...
     // 繼續下一步:
     return true;
    }
    </script>

    注意要return true來告訴瀏覽器繼續提交,如果return false,瀏覽器將不會繼續提交form,這種情況通常對應用戶輸入有誤,提示用戶錯誤信息后終止提交form。

    在檢查和修改<input>時,要充分利用<input type="hidden">來傳遞數據。

    例如,很多登錄表單希望用戶輸入用戶名和口令,但是,安全考慮,提交表單時不傳輸明文口令,而是口令的MD5。普通JavaScript開發人員會直接修改<input>:

    <!-- HTML -->
    <form id="login-form" method="post" onsubmit="return checkForm()">
     <input type="text" id="username" name="username">
     <input type="password" id="password" name="password">
     <button type="submit">Submit</button>
    </form>
    <script>
    function checkForm() {
     var pwd = document.getElementById('password');
     // 把用戶輸入的明文變為MD5:
     pwd.value = toMD5(pwd.value);
     // 繼續下一步:
     return true;
    }
    </script>

    這個做法看上去沒啥問題,但用戶輸入了口令提交時,口令框的顯示會突然從幾個*變成32個*(因為MD5有32個字符)。

    要想不改變用戶的輸入,可以利用<input type="hidden">實現:

    <!-- HTML -->
    <form id="login-form" method="post" onsubmit="return checkForm()">
     <input type="text" id="username" name="username">
     <input type="password" id="input-password">
     <input type="hidden" id="md5-password" name="password">
     <button type="submit">Submit</button>
    </form>
    <script>
    function checkForm() {
     var input_pwd = document.getElementById('input-password');
     var md5_pwd = document.getElementById('md5-password');
     // 把用戶輸入的明文變為MD5:
     md5_pwd.value = toMD5(input_pwd.value);
     // 繼續下一步:
     return true;
    }
    </script>

    注意到id為md5-password的<input>標記了name="password",而用戶輸入的id為input-password的<input>沒有name屬性。沒有name屬性的<input>的數據不會被提交。

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    JavaScript操作表單_動力節點Java學院整理

    JavaScript操作表單_動力節點Java學院整理:用JavaScript操作表單和操作DOM是類似的,因為表單本身也是DOM樹。 不過表單的輸入框、下拉框等可以接收用戶輸入,所以用JavaScript來操作表單,可以獲得用戶輸入的內容,或者對一個輸入框設置新的內容。 HTML表單的輸入控件主要有以下幾種: ᠊
    推薦度:
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 欧美XXXX黑人又粗又长精品| 亚洲国产精品嫩草影院| 无码精品一区二区三区在线| 在线精品亚洲一区二区三区| 亚洲日韩精品一区二区三区无码| 国产国产精品人在线视| 国产欧美国产精品第一区 | 国产精品久久久亚洲| 久久精品无码av| 亚洲高清国产AV拍精品青青草原| 亚洲AV成人无码久久精品老人| 国产免费久久精品丫丫| 亚洲永久精品ww47| 久久国产成人精品国产成人亚洲| 亚洲精品国精品久久99热一| 精品久久久久久无码免费| 亚洲精品福利视频| 国产精品高清一区二区三区不卡| 欧美日韩人妻精品一区二区在线| 久久91精品久久91综合| 久久久人妻精品无码一区| 99久久人人爽亚洲精品美女| 自拍中文精品无码| 久夜色精品国产一区二区三区| 国产精品V亚洲精品V日韩精品| 亚洲国产精品国自产拍AV| 免费精品精品国产欧美在线欧美高清免费一级在线 | 久久夜色精品国产噜噜麻豆| 人妻精品久久久久中文字幕| 久久精品成人免费观看97| 国内精品欧美久久精品| 香蕉依依精品视频在线播放| 国产三级精品三级在线专区1| 99久久精品免费| 91国内揄拍国内精品情侣对白 | 日本精品久久久久中文字幕8| 欧美精品VIDEOSEX极品| 国产精品一区三区| 精品一区二区三区高清免费观看 | 亚洲av成人无码久久精品| 人妻少妇精品中文字幕AV|