时间:2021-05-26
其中getElementsByName(name)方法是获取页面中所有具有name属性的元素,但这个方法在IE与标准浏览器中所取到的内容不一样。在IE中getElementsByName(name)方法所取到的元素是其本身就自带有name属性也就是form表单中所列出的所有元素(这些元素本身就自带有name属性);标准浏览器中getElementsByName(name)方法所取到的元素是具有name属性的元素(本身就带有此属性+人为添加的此属性)。所以如果在IE浏览器中用此方法来获取页面中所有带有name的元素时,只能取出其自身本来就具有此属性的那些元素(表单类元素)而那些人为添加的name属性元素则不会被取出来;标准浏览器则不会这样,它会将页面中所有带name属性的元素全部取出。
getElementsByName()与getElementsByTagName()方法的共同之类是它们会把所取得的页面元素组成一个元素集合并非是数组(虽然用firebug中的console.log()打印出来时是数组的形式)。如果用Object.porototype.toString.apply(arr)方法来查看取得的数据结果时,其返回的是“[object HTMLCollection]”而不是“[object Array]”。这样一来用这两种方法所取得的元素集合就不能像使用数组一样来调用数组的一些方法进行操作了而需要将此集合进行转换,将元素集合转换为数组的形式就可以像操作数组一样对里面的元素进行处理了。
这个元素集合具有如下的属性和方法:
1、元素索引(index)
2、元素集合的长度(length)
3、item()方法:通过传入不同的索引值可以取得集合中相应的元素。IE下没有此方法。
4、FF中还有一个namedItem(name)方法,取得具有name属性的第一个元素。只有FF下有这个方法。
关于元素集合向数组形式的转换方法有很多种,大家可以在网上搜索一下就有很多。也可以到司图正美的这篇《js将类数组对象转换成数组对象》博文中学习一。
以下是一个数组转换的方法:
复制代码 代码如下:
function makeArray(arr){
if(arr.item){
var len = arr.length;
var array = [];
while(len--){
array[len] = arr[len];
}
return array;
}
return Array.prototype.slice.call(arr);
}
这是一个小例子,可以看一下转换后的结果:
元素类数组与数组 getElements()函数中定义了一个数组,其内容分别是1,2,3,4,5,6 [Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
集合和数组在存储数据的时候是各有优缺点的,先总结下集合和数组的区别1.数组长度固定,集合长度不固定2.数组只能存储同一类型的元素,集合可以存储不同数据类型(在引
Array数组1.介绍数组是值的有序集合。每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示,称为索引。JavaScript数组是无类型:数组元素可以
通常在JavaScript中用for与forin遍历数组结果是没有什么区别的,它的循环变量i都是从0开始的数组索引(forin如果遍历的是非数组对象的属性集合,
scrollHeight,clientHeight,offsetHeight的区别说明:scrollHeight:DOM元素的实际内容的高度,不包border的
最近在看《javascript数据结构和算法》这本书,补一下数据结构和算法部分的知识,觉得自己这块是短板。链表:存储有序的元素集合,但不同于数组,链表中的元素在