亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

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

2024-09-01 08:30:48
字體:
來源:轉載
供稿:網友

用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或者falsetue.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>的數據不會被提交。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品999| 国产精品jvid在线观看蜜臀| 欧美激情成人在线视频| 亚洲国产精品99| 欧美肥婆姓交大片| 欧美电影在线免费观看网站| 亚洲欧美国产制服动漫| 久久久av网站| 欧美日韩另类在线| 日本成人在线视频网址| 欧美成人第一页| 国产精品电影在线观看| 麻豆一区二区在线观看| 欧美丰满少妇xxxxx| 福利视频导航一区| 国产精品久久久久久久美男| 亚洲欧美www| 亚洲欧洲国产伦综合| 日韩精品欧美国产精品忘忧草| 国产精品99一区| 国产精品免费久久久久影院| 国产一区视频在线播放| 久久久伊人欧美| 欧美xxxx18国产| 国产精品流白浆视频| 亚洲成色777777女色窝| 久久午夜a级毛片| 亚洲精品99久久久久中文字幕| 久久av红桃一区二区小说| 国产伦精品免费视频| 国产在线观看91精品一区| 狠狠躁夜夜躁人人爽天天天天97| 欧美亚州一区二区三区| 亚洲综合中文字幕在线| 国产欧美一区二区三区在线| 国内精品免费午夜毛片| 日韩福利伦理影院免费| 日韩免费av片在线观看| 欧美成人一二三| 粉嫩老牛aⅴ一区二区三区| 国产999精品久久久影片官网| 久久久精品网站| 亚洲一区二区中文| 欧美体内谢she精2性欧美| 欧美在线视频a| 成人欧美一区二区三区在线| 国产美女直播视频一区| 欧美另类交人妖| 日韩在线观看视频免费| 日韩成人网免费视频| 亚洲高清一二三区| 懂色aⅴ精品一区二区三区蜜月| 国产精品18久久久久久首页狼| 日韩欧美国产激情| 九九精品视频在线观看| 中文字幕免费精品一区| 亚洲黄色www| 综合欧美国产视频二区| 久久亚洲综合国产精品99麻豆精品福利| 国产69精品久久久久99| 亚洲国产精品yw在线观看| 久久久久久久久久久人体| 国产成人小视频在线观看| 亚洲国产欧美一区| 日韩在线精品视频| 伊人伊成久久人综合网站| 91中文字幕在线观看| 91在线视频导航| 国产精品九九九| 国产免费一区二区三区在线观看| 亚洲第一区在线观看| 精品亚洲国产成av人片传媒| 日韩精品999| 色先锋久久影院av| 97国产精品久久| 91精品免费看| 亚洲电影成人av99爱色| 黄色成人av网| 精品久久国产精品| 亚洲美女在线视频| 色哟哟入口国产精品| 91欧美日韩一区| 欧美黑人一级爽快片淫片高清| 亚洲一区二区三区777| 国产亚洲aⅴaaaaaa毛片| 欧美大片在线免费观看| 国产欧美精品一区二区三区-老狼| 日本欧美中文字幕| 国产一区二区在线免费视频| 91免费福利视频| 高潮白浆女日韩av免费看| 久久91亚洲精品中文字幕奶水| 7777精品久久久久久| 亚洲变态欧美另类捆绑| 91精品国产成人www| 久久久免费高清电视剧观看| 成人日韩在线电影| 黄色一区二区三区| 欧美激情免费视频| 国产精品视频最多的网站| 日本精品久久久久影院| 一区二区三区久久精品| 国自产精品手机在线观看视频| 日本久久久久亚洲中字幕| 欧美激情亚洲视频| 久久国产精品首页| 成人国产精品日本在线| 久久国产精品首页| 国产精品欧美久久久| 欧美激情a在线| 中文字幕日韩欧美| 久久国产精品影片| 久久久精品国产亚洲| 国产精品久久久久久久久免费看| 欧美精品第一页在线播放| 色99之美女主播在线视频| 国产精品久久久久免费a∨| 黄色精品一区二区| 国产成人精品国内自产拍免费看| 亚洲电影免费观看高清完整版在线| 日韩视频免费观看| 国精产品一区一区三区有限在线| 欧美黄网免费在线观看| 久久成人在线视频| 97人洗澡人人免费公开视频碰碰碰| 一区二区在线视频| 97久久精品人人澡人人爽缅北| 亚洲人成电影在线播放| 日韩中文字幕在线观看| 在线视频欧美日韩| 国产精品69久久久久| 一区二区三区视频观看| 中文字幕欧美日韩| 成人动漫网站在线观看| 国产精品高精视频免费| 国模精品视频一区二区三区| 亚洲国产精品yw在线观看| 久久精品免费电影| 午夜精品一区二区三区在线视| 国产精品欧美日韩久久| 亚洲精品欧美一区二区三区| 97在线视频观看| 日韩激情av在线播放| 欧美日韩国产一区中文午夜| 亚洲人成网站免费播放| 欧美诱惑福利视频| 成人黄色片在线| 欧美日韩亚洲精品一区二区三区| 国产在线日韩在线| 国内精品久久影院| 欧美成人在线影院| 亚洲欧洲在线免费| 亚洲最大激情中文字幕| 久久中文久久字幕| 亚洲伊人一本大道中文字幕| 亚洲美女在线看| 国产精品嫩草影院久久久| 欧美专区日韩视频| 欧美专区在线视频| 久久色免费在线视频| 成人性生交xxxxx网站| 国产在线观看不卡| 精品国产一区二区三区久久狼黑人| 亚洲午夜精品久久久久久性色|