WhatsApp网页版登录WhatsApp网页版登录

WhatsApp中文版

jq通过属性找父类_javascript查找父元素

摘要:使用js或者jquery查找父元素、子元素经常遇到。可是用起来总容易混淆,这里统一总结了一下,以后用起来相信会方便好多这里jquery向上查...

使用js或者jquery查找父元素、子元素经常遇到。可是用起来总容易混淆,这里统一总结了一下,以后用起来相信会方便好多

这里jquery向上查找父元素 用到的方法:closest() parents() parent()

向下查找子元素 用到的方法:find() children()

js用的是 children 属性

html代码

复制代码 代码如下:

段落1 查找父元素

11closest()向上查找最近的元素(返回零个或一个元素的 jQuery 对象)

21parent()方法

31parent("选择器")方法

段落2 查找子元素

查找table2的td find()方法

查找table2的td children()方法

js的children属性来查找

tbody2222

js代码:

复制代码 代码如下:

常见的getElementById,getElementsByName,getElementsByTagName。但外国人不满意这些API,于是搞出了getElementsByClassName,后来一点点又出现了jQuery选择器,这里只说原始js选择。

1.getElementById

这是最常用的选择器,通过id来定位:

例:

var test=document.getElementById("test").value;//获取文档中id为test的元素的值,并赋值给test变脸

2.getElementsByName

例:

var test=document.getElementByName("test");//获取文档中name为test的元素的节点,并赋值给test变量,此时test变量是一个数组

3.getElementsByTagName

例:

var test=document.getElementsByTagName("test");//获取文档中class为test的元素的节点telegram中文版,并赋值给test,此时test变量是一个数组 ,这个选择器在IE5,6,7,8中无法使用

4.getElementsByClassName

这个选择器在js的API中是找不到的,想要使用必须自己定义方法,通常的原理为先使用getElementsByTagName("*")取出文档中所有元素,然后进行遍历,使用正则表达式找出匹配的元素放入一个数组返回。网上有很多程序员实现了这个选择器,下面举两例:

(1)The Ultimate getElementsByClassName方案,作者为Robert Nyman,05年实现whatsapp网页版,可见老外许多东西在很早以前就走得很远了。

复制代码 代码如下:

//三个参数都是必需的,查找一网页中5007个类名为“cell”的元素,IE8历时1828 ~ 1844毫秒,

//IE6为4610 ~ 6109毫秒,FF3.5为46 ~ 48毫秒,opera10为31 ~ 32毫秒,Chrome为23~ 26毫秒,

//safari4为19 ~ 20毫秒

function getElementsByClassName(oElm, strTagName, strClassName){

var arrElements = (strTagName == "*" && oElm.all)? oElm.all :

oElm.getElementsByTagName(strTagName);

var arrReturnElements = new Array();

strClassName = strClassName.replace(/-/g, "-");

var oRegExp = new RegExp("(^|s)" + strClassName + "(s|$)");

var oElement;

for(var i=0; i < arrElements.length; i++){

oElement = arrElements

if(oRegExp.test(oElement.className)){

arrReturnElements.push(oElement);

return (arrReturnElements)

(2)由Dustin Diaz(《JavaScript Design Patterns》的作者)提供,但兼容性不如上面的whatsapp网页版,不支持IE5。

复制代码 代码如下:

//后两参数是可靠的,查找一网页中5007个类名为“cell”的元素,IE8历时78毫秒,IE6历时125~171毫秒

//FF3.5为42 ~ 48毫秒,opera10为31 毫秒,Chrome为22~ 25毫秒,safari4为18 ~ 19毫秒

var getElementsByClass = function(searchClass,node,tag) {

var classElements = new Array();

if ( node == null )

node = document;

if ( tag == null )

tag = '*';

var els = node.getElementsByTagName(tag);

var elsLen = els.length;

var pattern = new RegExp("(^|s)"+searchClass+"(s|$)");

for (i = 0, j = 0; i < elsLen; i++) {

if ( pattern.test(els

.className) ) {

classElements

= els

j++;

return classElements;

--------------------------------------------------------------------------------------------------------------------------------------------------------

注:this可以表示当前元素的节点。

--------------------------------------------------------------------------------------------------------------------------------------------------------

下面是配合事件等知识点的一些常用的使用方法:

复制代码 代码如下:

//提交id为test的表单

document.getElementById("test").submit();

//将id为test元素的边框设置为2个像素,实体,红色

document.getElementById("test").style.border="2px solid red";

//鼠标移动或移出id为test的元素,改变其背景色

function test(){

document.getElementById("test").onmouseover=function(){document.getElementById("test2").style.backgroundColor="red"};

document.getElementById("test").onmouseout=function(){document.getElementById("test2").style.backgroundColor="blue"};

//弹出文档中name为test的元素的个数

function test()

var test=document.getElementsByName("test");

alert(test.length);

相关文章

«    2025年8月    »
123
45678910
11121314151617
18192021222324
25262728293031

控制面板

您好,欢迎到访网站!
  查看权限

网站分类

最近发表

最新留言

    文章归档

    标签列表

    友情链接