querySelector获得兄弟DOM元素 父级DOM元素 子级DOM元素

2020-05-07 13:28:23

参考地址 js定位大全获取节点的兄弟,父级,子级元素含robot实例

 一、js定位兄弟,父级,子级元素

<div id="test">

   <div></div>

   <div></div>

 </div>

 所有DOM方法

var el = document.getElementById('xxx');
var el = document.getElementByName('xxx');
var els = document.getElementsBy('highlight'); 

var els = document.getElementsBy('td');
tips:


=======================附注=========================
解释:getElementsByClassName()是HTML5的DOM API。
:document.getElementsByClassName("wrapper"); //取得DOM中所有class = "wrapper"的元素

解释:querySelector()和querySelectorAll()
是新标准的Selectors API(选择符API)。IE8+、FF3.5+、Safari 3.1+、Chrome、Opera 10+支持

  querySelector()接受一个作为参数,然后返回DOM中匹配的第一个元素
  querySelectorAll()接受一个作为参数,然后返回DOM中匹配的元素的集合数组

 原生的JS获取ID为test的元素下的子元素。可以用:

var a = docuemnt.getElementById("test").getElementsByTagName("div");  这样是没有问题的

 此时a.length=2;

 

复制代码

<script>   function dom() {

              var s= document.getElementById("test"); 

              del_ff(s);    //清理空格 

              var chils= s.childNodes;  //得到s的全部子节点 

              var par=s.parentNode;   //得到s的父节点 

              var ns=s.nextSibling;   //获得s的下一个兄弟节点 

              var ps=s.previousSibling;  //得到s的上一个兄弟节点 

              var fc=s.firstChild;   //获得s的第一个子节点 

              var lc=s.lastChild;   //获得s的最后一个子节点 
            } 

</script>

复制代码

 

 

下面介绍JQUERY的父,子,兄弟节点查找方法

 

jQuery.parent(expr)  找父亲节点,可以传入expr进行过滤,比如$("span").parent()或者$("span").parent(".class")

jQuery.parents(expr),类似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素

jQuery.children(expr).返回所有子节点,这个方法只会返回直接的孩子节点,不会返回所有的子孙节点

jQuery.contents(),返回下面的所有内容,包括节点和文本。这个方法和children()的区别就在于,包括空白文本,也会被作为一个

jQuery对象返回,children()则只会返回节点

 jQuery.prev(),返回上一个兄弟节点,不是所有的兄弟节点

 jQuery.prevAll(),返回所有之前的兄弟节点

 jQuery.next(),返回下一个兄弟节点,不是所有的兄弟节点

 jQuery.nextAll(),返回所有之后的兄弟节点

 jQuery.siblings(),返回兄弟姐妹节点,不分前后

 jQuery.find(expr),跟jQuery.filter(expr)完全不一样。

jQuery.filter()是从初始的jQuery对象集合中筛选出一部分,而

jQuery.find()的返回结果,不会有初始集合中的内容,比如$("p"),find("span"),是从<p>元素开始找<span>,等同于$("p span")

 robotframework实例:

Execute Javascript  var ele=document.getElementsByName()(3).nextSibling;ele.onclick();

 实例1:

实例2:

Execute Javascript    var ele=document.getElementById("viewtable").getElementsByTagName("tbody")(0).getElementsByTagName("td"); for(var i=0;i<ele.length;i++)  
    { if(ele[i].innerHTML=="${searchTitle}") { ele[i].onclick()} }


  • 2020-04-08 22:46:28

    Element的操作方法

    Element 是一个通用性非常强的基类,所有 Document 对象下的对象都继承自它。这个接口描述了所有相同种类的元素所普遍具有的方法和属性。一些接口继承自 Element 并且增加了一些额外功能的接口描述了具体的行为。例如, HTMLElement 接口是所有 HTML 元素的基本接口,而 SVGElement 接口是所有 SVG 元素的基础。大多数功能是在这个类的更深层级(hierarchy)的接口中被进一步制定的。

  • 2020-04-12 17:42:43

    Node.js设置CORS跨域请求中多域名白名单的方法

    在Node.js中,res的响应头Header中的 Access-Control-Allow-Origin 属性不能匹配除 (*) 以外的正则表达式的,域名之间不能也用逗号分隔。也就是说, Access-Control-Allow-Origin 的属性值只允许设置为单个确定域名字符串或者 (*)。

  • 2020-04-14 09:40:59

    CSS3实现文字描边的2种方法

    首先想到去看CSS3有没有什么属性可以实现,后来被我找到了text-stroke     该属性是一个复合属性,可以设置文字宽度和文字描边颜色      该属性使用很简单:text-stroke:1px #f00;(1px是文字宽度,#ff是文字描边颜色)

  • 2020-04-14 09:42:47

    用 TypeScript 编写 npm 模块

    自从开始使用 Node.js 已经一年多,写的代码越多,越是觉得自己提高的越慢。想来应该有没有将单一功能的代码封装在一个独立模块,而导致代码稍微多一点就维护困难的原因。

  • 2020-04-14 09:46:25

    TypeScript 入门教程

    TypeScript 是 JavaScript 的超集,扩展了 JavaScript 的语法,因此现有的 JavaScript 代码可与 TypeScript 一起工作无需任何修改,TypeScript 通过类型注解提供编译时的静态类型检查。 TypeScript 可处理已有的 JavaScript 代码,并只对其中的 TypeScript 代码进行编译。

  • 2020-04-14 09:51:03

    package.json 字段说明

    package.json 有很多字段,也有很多官方字段,我们需要知道他们的具体是做什么的才能很好的运用