欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中document.forms[0]與getElementByName區(qū)別

 更新時(shí)間:2015年01月21日 15:06:38   投稿:hebedich  
在很多情況下JavaScript中document.forms[0]與getElementByName這兩種用法沒有區(qū)別,這片文章詳細(xì)的解釋了兩者的區(qū)別和用法,有興趣的朋友可以參考一下。

首先我們來(lái)看個(gè)示例:

復(fù)制代碼 代碼如下:

<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頁(yè)面中有一個(gè)form表單或者多個(gè)form表單的時(shí)候,都是返回一個(gè)NodeList類型的form數(shù)組
document.forms[0].usernames,這里的usernames可以是id的值,也可以是name的值,在這里這兩個(gè)屬性是等價(jià)的。而且,不會(huì)區(qū)分組件是文本框,是單選框,還是復(fù)選框。

這時(shí)要區(qū)分兩種情況,

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

此時(shí),alert(document.forms[0].usernames.length)返回的是undefined,因?yàn)閕nput組件沒有l(wèi)ength這個(gè)屬性。
有兩個(gè)或者兩個(gè)以上input的id或者name為'usernames'的時(shí)候,document.forms[0].usernames返回的是NodeList數(shù)組,此時(shí),
alert(document.forms[0].usernames.length)會(huì)返回?cái)?shù)組的長(zhǎng)度,上邊的例子中,返回值是3
所以,當(dāng)使用js進(jìn)行全選的時(shí)候,要考慮同名復(fù)選框有一個(gè)和多個(gè)的情況

復(fù)制代碼 代碼如下:

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

有一個(gè)組件id為'usernames'或者多個(gè)組件id為'usernames',document.getElementById('usernames')返回的值都是一個(gè)表單組件,當(dāng)有多個(gè)組件id為'usernames',返回的是第一個(gè)id為'usernames'組件。
有一個(gè)組件name為'usernames'或者多個(gè)組件name為'usernames',document.getElementsByName()返回的都是HTMLCollection數(shù)組。注意與document.getElementsByTagName()的區(qū)別,后者是根據(jù)標(biāo)簽類別獲取數(shù)組。
var names = document.getElementsByTagName("usernames"),alert(names[0])這里返回的結(jié)果是undefined,我原來(lái)把byName與byTagName弄混了,而沒有標(biāo)簽是以u(píng)sernames開始的,<usernames value=''></usernames>這是不存在的。
但是getElementsByTagName返回的依然是數(shù)組集合,其不含任何內(nèi)容,names[0]不存在,所以返回的是undefined,因?yàn)槌鰯?shù)組范圍的時(shí)候,彈出的都是undefined值。
var test = {'0','1','2',};alert(test[3]);返回的是undefined.

相關(guān)文章

  • javascript實(shí)現(xiàn)禁止復(fù)制網(wǎng)頁(yè)內(nèi)容匯總

    javascript實(shí)現(xiàn)禁止復(fù)制網(wǎng)頁(yè)內(nèi)容匯總

    本文給大家匯總介紹了幾種使用javascript和CSS實(shí)現(xiàn)禁止復(fù)制頁(yè)面內(nèi)容的方法,非常的實(shí)用,有需要的小伙伴可以參考下。
    2015-12-12
  • ES6模塊化的import和export用法方法總結(jié)

    ES6模塊化的import和export用法方法總結(jié)

    這篇文章主要介紹了ES6模塊化的import和export用法方法總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-08-08
  • JavaScript中的常見問題解決方法(亂碼,IE緩存,代理)

    JavaScript中的常見問題解決方法(亂碼,IE緩存,代理)

    這篇文章主要是對(duì)JavaScript中的常見問題解決方法(亂碼,IE緩存,代理)進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來(lái)參考下,希望對(duì)大家有所 幫助
    2013-11-11
  • js仿百度音樂全選操作

    js仿百度音樂全選操作

    這篇文章主要為大家詳細(xì)介紹了js仿百度音樂全選操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Javascript document.referrer判斷訪客來(lái)源網(wǎng)址

    Javascript document.referrer判斷訪客來(lái)源網(wǎng)址

    用簡(jiǎn)單幾行的javascript,就可抓到使用的來(lái)源,以及作出一些防范的措施。
    2009-12-12
  • js for終止循環(huán) 跳出多層循環(huán)

    js for終止循環(huán) 跳出多層循環(huán)

    這篇文章主要介紹了js for等循環(huán) 跳出多層循環(huán),終止循環(huán)執(zhí)行的方法,需要的朋友可以參考下
    2018-10-10
  • JS?中的?Event?Loop?是什么你真的懂

    JS?中的?Event?Loop?是什么你真的懂

    Event Loop,簡(jiǎn)單翻譯就是?事件循環(huán),是 JS 語(yǔ)言下實(shí)現(xiàn)運(yùn)行時(shí)的一個(gè)機(jī)制,這篇文章主要介紹了JS?中的?Event?Loop?的基本知識(shí),需要的朋友可以參考下
    2022-06-06
  • JS?debug跳過的7種方法總結(jié)

    JS?debug跳過的7種方法總結(jié)

    在JS開發(fā)過程中,代碼可能存在一些語(yǔ)法或者邏輯上的錯(cuò)誤,導(dǎo)致程序不能得到我們想要的結(jié)果,這時(shí)就需要我們找到并修復(fù)這些錯(cuò)誤,我們將查找和修復(fù)錯(cuò)誤的過程稱為調(diào)試或代碼調(diào)試,這篇文章主要給大家介紹了關(guān)于JS?debug跳過的7種方法,需要的朋友可以參考下
    2023-07-07
  • JS只能輸入正整數(shù)的簡(jiǎn)單實(shí)例

    JS只能輸入正整數(shù)的簡(jiǎn)單實(shí)例

    下面小編就為大家?guī)?lái)一篇JS只能輸入正整數(shù)的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2016-10-10
  • JS小游戲之極速快跑源碼詳解

    JS小游戲之極速快跑源碼詳解

    這篇文章主要介紹了JS小游戲之極速快跑源碼詳解,對(duì)游戲的主要流程及原理進(jìn)行了較為詳細(xì)的講解,并附有完整實(shí)例源碼,需要的朋友可以參考下
    2014-09-09

最新評(píng)論