一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - JavaScript中document.forms[0]與getElementByName區別

JavaScript中document.forms[0]與getElementByName區別

2021-07-21 16:47hebedich JavaScript

在很多情況下JavaScript中document.forms[0]與getElementByName這兩種用法沒有區別,這片文章詳細的解釋了兩者的區別和用法,有興趣的朋友可以參考一下。

首先我們來看個示例:

 

復制代碼 代碼如下:

<form name="buyerForm" method="post" action="/mysport/control/user/list.do">
<input type="checkbox" id="usernames" value="testtest" >testtest<br>
<input type="checkbox" name="usernames" value="testtest" >testtest<br>
<input type="text" id="usernames" value="testtest" >testtest<br>
</form>

 

document.forms[0]在HTML頁面中有一個form表單或者多個form表單的時候,都是返回一個NodeList類型的form數組
document.forms[0].usernames,這里的usernames可以是id的值,也可以是name的值,在這里這兩個屬性是等價的。而且,不會區分組件是文本框,是單選框,還是復選框。

這時要區分兩種情況

有一個input的id或者name為'usernames'的時候,document.forms[0].usernames返回的是具體的input組件,這時如果操作的話,就要按照具體的組件操作方法來使用。

此時,alert(document.forms[0].usernames.length)返回的是undefined,因為input組件沒有length這個屬性。
有兩個或者兩個以上input的id或者name為'usernames'的時候,document.forms[0].usernames返回的是NodeList數組,此時,
alert(document.forms[0].usernames.length)會返回數組的長度,上邊的例子中,返回值是3
所以,當使用js進行全選的時候,要考慮同名復選框有一個和多個的情況

 

復制代碼 代碼如下:

function allSelect(){
var form = document.forms[0];
var state = form.allselectbox.checked;
var length = form.usernames.length;//當有兩個或者兩個以上的復選框name為usernames的時候,返回的是數組的長度
//當有一個復選框name為usernames的時候,form.usernames返回的是復選框對象,而不是數組,所以其length屬性是undefined
if(length){ //在javascript中,只要被判斷的條件是0,null,或者undefined,均被認為是false,其他情況均認為是true
for(var i=0;i<length;i++){
form.usernames[i].checked=state;
}
}
else{
form.usernames.checked=state;
}
}

 

有一個組件id為'usernames'或者多個組件id為'usernames',document.getElementById('usernames')返回的值都是一個表單組件,當有多個組件id為'usernames',返回的是第一個id為'usernames'組件。
有一個組件name為'usernames'或者多個組件name為'usernames',document.getElementsByName()返回的都是HTMLCollection數組。注意與document.getElementsByTagName()的區別,后者是根據標簽類別獲取數組。
var names = document.getElementsByTagName("usernames"),alert(names[0])這里返回的結果是undefined,我原來把byName與byTagName弄混了,而沒有標簽是以usernames開始的,<usernames value=''></usernames>這是不存在的。
但是getElementsByTagName返回的依然是數組集合,其不含任何內容,names[0]不存在,所以返回的是undefined,因為超出數組范圍的時候,彈出的都是undefined值。
var test = {'0','1','2',};alert(test[3]);返回的是undefined.

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品91一区二区三区 | 好大好想要 | 国产精品不卡高清在线观看 | 国产青草视频在线观看免费影院 | 国产精品天天看特色大片不卡 | 国产思妍小仙女一二区 | 国产成人亚洲精品91专区高清 | 亚洲男女在线 | 星空传媒在线视频 | 91精品国产亚一区二区三区 | 日本漫画工囗全彩内番e绅 日本伦理动漫在线观看 | 厨房play黄瓜进去小说h | 91高清国产经典在线观看 | blackedvideos黑人| 国产成人综合一区人人 | 国产精品久久久99 | 大陆国语自产精品视频在 | 欧美最猛性xxxxx69交 | 四虎地址 | 狠狠色伊人亚洲综合网站色 | 极品虎白女在线观看一线天 | 午夜小视频免费观看 | 午夜片无码区在线观看 | 国产成人8x视频一区二区 | 亚洲精品6久久久久中文字幕 | 亚洲精品久久久久AV无码 | 国色天香社区在线 | 国产手机在线观看 | 国产一级片免费视频 | 国产色视频一区二区三区 | xxxx俄罗斯大白屁股 | 日本免费一区二区三区a区 日本免费三片在线观看 | 亚洲国产欧美另类 | 久久99亚洲AV无码四区碰碰 | 国产91在线免费 | 1024免费观看完整版在线播放 | 毛片小视频 | 日本黄大片影院一区二区 | 亚洲欧美日韩成人一区在线 | 99久久精品免费看国产四区 | 青草国内精品视频在线观看 |