JS获取网页中HTML元素的几种方法
编写js程序的时候最常使用的就是获取网页中的html元素,并进行处理,我在网上发现了一篇获取html对象的几种方法进行整理的帖子,发上来大家一块学习~
getElementById getElementsByName getElementsByTagName 大概介绍
getElementById ,getElementsByName ,getElementsByTagName
后两个是得到集合,byid只是得到单个对象
getElementById 的用法
举个例子:
<a id="link1" name="link1" href=http://homepage.yesky.com>网页陶吧</a>
同一页面内的引用方法:
1、使用id:
link1.href,返回值为http://homepage.yesky.com/
2、使用name:
document.all.link1.href,返回值为http://homepage.yesky.com/
3、使用sourseIndex:
document.all(4).href //注意,前面还有HTML、HEAD、TITLE和BODY,所以是4
4、使用链接集合:
document.anchors(0).href
//全部的集合有all、anchors、applets、areas、attributes、behaviorUrns、bookmarks、boundElements、cells、childNodes、children、controlRange、elements、embeds、filters、forms、frames、images、imports、links、mimeTypes、options、plugins、rows、rules、scripts、styleSheets、tBodies、TextRectangle,请参考MSDN介绍。
其实方法3和方法4是一样使用的集合,只是一个是all,可以包括页面所有标记,而anchors只包括链接。
5、getElementById:
document.getElementById("link1").href
6、getElementsByName:
document.getElementsByName("link1")[0].href //这也是一个集合,是所有name等于该方法所带参数的标记的集合
7、getElementsByTagName:
document.getElementsByTagName("A")[0].href //这也是一个集合,是所有标记名称等于该方法所带参数的标记的集合
8、tags集合:
document.all.tags("A")[0].href
//与方法7一样是按标记名称取得一个集合
除此之外:
event.scrElement可以获得触发时间的标记的引用;
document.elementFromPoint(x,y)可以获得x和y坐标处的元素的引用;
document.body.componentFromPoint(event.clientX,event.clientY)可以获得鼠标所在处元素的引用;
还可以通过元素的父子节点和兄弟节点关系来引用,如nextSibling(当前节点的后一节点)、previousSibling(当前节点的前一节点)、childNodes、children、firstChild、lastChild、parentElement等都是父子节点和兄弟节点的一些引用;还不仅限于此。
上面是同一页面内的常见引用方法,另外还涉及到不同页面中的
getElementsByName返回的是所有name为指定值的所有元素的集合
“根据 NAME 标签属性的值获取对象的集合。”
集合比数组要松散的多, 集合里每个子项的类型可以不同, 集合只是把某些元素放在一起作为一类来使用, 相比之下数组就严格多了, 每个子项都是统一的类型. document.getElementsByName, document.getElementsByTagName, document.formName.elements 这类方法所得到的结果都是集合.
以下是引用片段: function get(){
var xx=document.getElementById("bbs")
alert("标记名称:"+xx.tagName);
}
function getElementName(){
var ele = document.getElementsByName("happy");
alert("无素为happy的个数:" + ele.length);
}
获取文件指定的元素
document.getElementsByName()这个方法.它对一个和多个的处理是一样的,我们可以用:
Temp = document.getElementsByName('happy')来引用
当Temp只有1个的时候,那么就是Temp[0],有多个的时候,用下标法Temp循环获取
也有例外:
在ie 中getElementsByName(“test“)的时候返回的是id=test的object数组,而firefox则返回的是name= test的object的数组。
按照w3c的规范应该是返回的是name= test的object的数组。
firefox和ie中的getElementByID相同:获取对 ID 标签属性为指定值的第一个对象的引用。
注意getElementsByName 有s在里面
document.getElementById()可以控制某个id的tag
document.getElementsByName(),返回的是一个具有相同 name 属性的元素的集合,而不是某个,注意有“s”。
而 document.getElementsByTagName() 返回的是一组相同 TAG 的元素集合。
同一个name可以有多个element,所以用document.getElementsByName("theName")
他return 一个collection,引用的时候要指名index
var test = document.getElementsByName('testButton')[0];
id那个,是唯一的
还应该注意:对类似没有name属性,对它name属性为伪属性document.getElementsByName() 会失效,当然TD可以设置ID属性,然后用 document.getElementsByID("DDE_NODAY"); 调用
*****************************************************************************************************************
帐 号:
最长16位,请使用英文字母/数字/-/_的组合
function check_uid()
{
var uid = document.frmUserInfo.UserID.value;
if(uid!="")
{
var url = "check_uid.php?UserID="+uid;
window.open(url,"newwinname","width=430,height=198,scrollbars=yes");
}
else
alert("请填写帐号");
}
- 相关阅读
- ( 2014-9-15 16:09:32 )利用javascript简短功能就可以检查form表单中的元素是否已经填写
- ( 2014-9-11 20:43:31 )用javscript实现为表格的每一行自动加上序号
- ( 2014-9-10 9:14:15 )鼠标放在表格区域内,当前格的一整行和一整列变色
- ( 2014-9-6 15:48:21 )Dreamweaver在onLoad运行_onOpen.htm时,发生了以下javascript错误
- ( 2013-12-31 19:47:11 )js兼容多个浏览器右下角漂浮广告
- ( 2013-12-31 19:47:11 )兼容ie6+和火狐的禁止右键
- ( 2012-11-1 9:03:47 )鼠标经过表格列时变色
- ( 2012-7-10 16:27:17 )利用JavaScript获取现在时间日期与农历
- 共有0条关于《JS获取网页中HTML元素的几种方法》的评论
- 发表评论
您发布的评论即表示同意遵守以下条款:
一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家、社会、集体和公民的合法权益;
二、不得发布国家法律、法规明令禁止的内容;互相尊重,对自己在本站的言论和行为负责;
三、本站对您所发布内容拥有处置权。
- 更多>>同类信息
- 介绍JavaScript里比较和逻辑运算符
- window.location.href在firefox火狐中不兼容的解决办法
- javascript 表单(文本框)触发鼠标事件大全
- javascript里confirm在外部文件中调用方法
- [转]javascript缓冲效果
- Javascript JS 限制复选框的选择个数
- 在网页添加创建快捷方式的按钮
- 以前的QQ强聊不管了,这个是非常管用的QQ强聊
- 更多>>最新添加文章
- 批量删除access字段里面fld.Properties.Delete
- ASP操作access或sqlserver数据库的函数库
- asp采用access数据库搜索信息时因为日文片假名问题提示“Microsoft JET Database Engine 错误80040e14”的解决方法
- asp中求两个数的百分比(利用百分比函数FormatPercent就可以自带%的符号)
- asp利用sql操作数据表、数据库的一些方法
- rs操作数据表记录集对象的方法
- asp利用dateadd获得上个月、本月、下个月的第一天和最后一天
- asp随机显示字符长度与类型(可随机显示数字、小写字母、大写字母,可以做为随机密码使用)
- 业务 QQ:565449214
- 手机:139 6134 7334
- 更多>>随机抽取信息
- 经典实用的触发型导航菜单
- 静态页面在文本框中输入数字,表格直接算出相应的结果
- 时间能证明一切。
- 利用java控制图片的大小
- 生意就是这样做成的
- 回家的感觉真好。
- ASP读取ACCSS数据代码
- 一张背景实现自适应九宫格