JavaScript中document.forms[0]與getElementByName區(qū)別
首先我們來看個示例:
<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數(shù)組
document.forms[0].usernames,這里的usernames可以是id的值,也可以是name的值,在這里這兩個屬性是等價的。而且,不會區(qū)分組件是文本框,是單選框,還是復選框。
這時要區(qū)分兩種情況,
有一個input的id或者name為'usernames'的時候,document.forms[0].usernames返回的是具體的input組件,這時如果操作的話,就要按照具體的組件操作方法來使用。
此時,alert(document.forms[0].usernames.length)返回的是undefined,因為input組件沒有l(wèi)ength這個屬性。
有兩個或者兩個以上input的id或者name為'usernames'的時候,document.forms[0].usernames返回的是NodeList數(shù)組,此時,
alert(document.forms[0].usernames.length)會返回數(shù)組的長度,上邊的例子中,返回值是3
所以,當使用js進行全選的時候,要考慮同名復選框有一個和多個的情況
function allSelect(){
var form = document.forms[0];
var state = form.allselectbox.checked;
var length = form.usernames.length;//當有兩個或者兩個以上的復選框name為usernames的時候,返回的是數(shù)組的長度
//當有一個復選框name為usernames的時候,form.usernames返回的是復選框?qū)ο?,而不是?shù)組,所以其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數(shù)組。注意與document.getElementsByTagName()的區(qū)別,后者是根據(jù)標簽類別獲取數(shù)組。
var names = document.getElementsByTagName("usernames"),alert(names[0])這里返回的結(jié)果是undefined,我原來把byName與byTagName弄混了,而沒有標簽是以usernames開始的,<usernames value=''></usernames>這是不存在的。
但是getElementsByTagName返回的依然是數(shù)組集合,其不含任何內(nèi)容,names[0]不存在,所以返回的是undefined,因為超出數(shù)組范圍的時候,彈出的都是undefined值。
var test = {'0','1','2',};alert(test[3]);返回的是undefined.
相關文章
javascript實現(xiàn)禁止復制網(wǎng)頁內(nèi)容匯總
本文給大家匯總介紹了幾種使用javascript和CSS實現(xiàn)禁止復制頁面內(nèi)容的方法,非常的實用,有需要的小伙伴可以參考下。2015-12-12
ES6模塊化的import和export用法方法總結(jié)
這篇文章主要介紹了ES6模塊化的import和export用法方法總結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
JavaScript中的常見問題解決方法(亂碼,IE緩存,代理)
這篇文章主要是對JavaScript中的常見問題解決方法(亂碼,IE緩存,代理)進行了詳細的分析介紹,需要的朋友可以過來參考下,希望對大家有所 幫助2013-11-11
Javascript document.referrer判斷訪客來源網(wǎng)址
用簡單幾行的javascript,就可抓到使用的來源,以及作出一些防范的措施。2009-12-12

