selenium之document.querySelector()方法

document.querySelector()方法

1. 常用的三种获取元素的js方式

  • document.getElementById("");
  • document.getElementsByClassName();
  • document.getElementsByTagName();
复制代码
 var doc=document;
 
var box=doc.getElementById("box");
 
var li=box.getElementsByTagName("li");
 
var surfaces=box.getElementsByClassName("surfaces");

querySelector()可以直接加点击事件,而querySelectorAll()不能直接加点击事件

2. querySelector()

var node = document.querySelector("#lover"); // 获取文档中的第一个id=lover的元素

var node = document.querySelector(".lover"); // 获取文档中的第一个class="lover"的元素

var node = document.querySelector("p.lover"); // 获取class="lover" 的第一个p元素

var node = document.querySelector("a[target]");// 获取第一个带target属性的a元素

var element = document.querySelector('.foo,.bar');//返回带有foo或者bar样式类的首个元素

document.querySelector(\"body\").style=""; // 移除style属性

document.querySelector("h2,h3").style.backgroundColor = "blue";//为文档的第一个h2元素添加背景颜色,但是,如果文档中<h3>元素位于<h2>元素之前,<h3>元素将会被设置指定的背景颜色,总结,多元素选择时,哪个先匹配就是谁咯,只有一个被选中。

querySelector() 方法仅仅返回匹配指定选择器的第一个元素。

3. querySelectorAll

elementList = document.querySelectorAll(selectors);

elementList 是一个静态的 NodeList 类型的对象。

selectors 是一个由逗号连接的包含一个或多个 CSS 选择器的字符串。

查找文档中共包含 "target" 属性的 <a> 标签,并为其设置边框:

复制代码
var x = document.querySelectorAll("a[target]");
 
var i;
 
for (i = 0; i < x.length; i++) {
 
        x[i].style.border = "10px solid red";
 
}

let t0 = window.performance.now();
let li = document.querySelectorAll('li');
console.log("li 的数量", li.length);
for (let i = 0; i < li.length; i++) {
    li[i].textContent = i;
}
let t1 = window.performance.now();
console.log("耗时" + (t1 - t0) + "毫秒");

当页面中出现多个相同class标签(或者多个相同标签(比如多个div))时,如果你需要返回所有的元素,请使用 querySelectorAll() 方法替代。

该方法返回所有满足条件的元素,结果是个nodeList集合。查找规则与前面所述一样。 ----> querySelectorAll 得到一个伪数组 DOM。

ParentNode.querySelectorAll()的结果是NodeList数组,但是又不是一般的js数组(Array),所以也不能直接调用Array的方法。

相关推荐
Moment7 分钟前
想做远程工作?这些技术栈和思维得准备好 🥰🥰🥰
前端·javascript·面试
晓得迷路了44 分钟前
栗子前端技术周刊第 83 期 - Rolldown-Vite、Angular v20、Docusaurus 3.8...
前端·javascript·vite
独立开阀者_FwtCoder1 小时前
如何让 Cursor AI Agent始终遵守项目规范:使用自动规则生成技术
java·前端·javascript
独立开阀者_FwtCoder1 小时前
尤雨溪宣布:Vue 3.6 重大更新!Vite 将彻底重写!
前端·javascript·后端
江城开朗的豌豆1 小时前
JavaScript篇:如何实现add(1)(2)(3)()=6?揭秘链式调用的终极奥义!
前端·javascript·面试
江城开朗的豌豆1 小时前
JavaScript篇:GET、POST、PUT...傻傻分不清?一篇文章带你玩转HTTP请求!
前端·javascript·面试
烛阴11 小时前
Date-fns教程:现代JavaScript日期处理从入门到精通
前端·javascript
小蜜蜂嗡嗡12 小时前
flutter项目迁移空安全
javascript·安全·flutter
江城开朗的豌豆12 小时前
JavaScript篇:a==0 && a==1 居然能成立?揭秘JS中的"魔法"比较
前端·javascript·面试
江城开朗的豌豆13 小时前
JavaScript篇:setTimeout遇上for循环:为什么总是输出5?如何正确输出0-4?
前端·javascript·面试