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-11-17 10:13:16

    Vue.observable()进行状态管理

    随着组件的细化,就会遇到多组件状态共享的情况, Vuex当然可以解决这类问题,不过就像 Vuex官方文档所说的,如果应用不够大,为避免代码繁琐冗余,最好不要使用它,今天我们介绍的是 vue.js 2.6 新增加的 Observable API ,通过使用这个 api 我们可以应对一些简单的跨组件数据状态共享的情况。

  • 2020-11-17 10:17:18

    MongoDB日志文件查看

    默认情况下,MongoDB在此路径/var/log/mongodb/mongodb.log创建日志文件,如果找不到该日志文件,请检查MongoDB配置文件。

  • 2020-11-17 11:57:16

    app抓包无数据

    我们经常在wifi设置中 设置代理到我们的pc http代理软件上,多数情况下,此时我们开启的app流量都可以在代理软件上看到,比如charles , fiddler等等。 但是细心的人会发现 某些大厂的app 某些请求 在这些 http代理软件上就是抓不到, 给人的感觉就是 流量没从代理软件走一样。

  • 2020-11-17 11:57:55

    app抓不到包,解决很简单

    1.手机安装virtualXpost 并激活xpost 框架,如有问题自行百度。 2.安装justTrustMe,然后再virtualXpost中添加此模块 3.安装手机抓包神器packet capture 4.在virtualXpost中运行app,并打开packet capture抓包就行

  • 2020-11-17 16:50:16

    JS常见加密混淆方式

    目录 前端js常见混淆加密保护方式 eval方法等字符串参数 emscripten WebAssembly js混淆实现 JSFuck AAEncode JJEncode 代码压缩 变量名混淆 字符串混淆 自我保护,比如卡死浏览器 控制流平坦化 僵尸代码注入 对象键名替换 禁用控制台输出 调试保护,比如无限Debug,定时Debug 域名锁定

  • 2020-11-17 17:08:28

    用js编写WebAssembly ,WebAssembly 现状与实战

    自从 JavaScript 诞生起到现在已经变成最流行的编程语言,这背后正是 Web 的发展所推动的。Web 应用变得更多更复杂,但这也渐渐暴露出了 JavaScript 的问题:

  • 2020-11-17 17:28:06

    AssemblyScript 开发WebAssembly 教程

    WebAssembly 以及通过 AssemblyScript 的扩展,不会使每个网站都神奇地变得更快,但是这并不重要。 WebAssembly 之所以令人兴奋,是因为它可以使更多的应用在 Web 变得中可行。

  • 2020-11-17 21:15:48

    如何保障 API 接口的安全性?前端如何加密

    一、1. HTTP 请求中的来源识别 二、2. 数据加密 三、3. 数据签名 四、4. 时间戳 五、5. AppID 六、6. 参数整体加密 七、7. 限流 八、8. 黑名单 九、1. 压缩 十、2. 混淆 undefined、3. 加密