Webapi梳理

219 阅读2分钟

小知识,大挑战!本文正在参与“程序员必备小知识”创作活动

Web Api 的概念

浏览器提供了一些操作浏览器功能与页面元素的API,本次整理了一些常用操作页面元素的Api

document.querySelector()

该方法会返回文档中与指定选择器或选择器组匹配的第一个页面元素。如果找不到匹配项,则返回null

语法

 let element = document.querySelector(selectors);

参数

  • selectors

    该字符串必须是有效的CSS选择器字符串

返回值

文档中与指定的一组CSS选择器匹配的第一个页面元素。如果没有匹配到,则返回null

实例

实例1

<!DOCTYPE html>
<html lang="en">
 <head>
   <meta charset="UTF-8" />
   <meta http-equiv="X-UA-Compatible" content="IE=edge" />
   <meta name="viewport" content="width=device-width, initial-scale=1.0" />
   <title>Document</title>
 </head>
 <body>
   <div class="first">
     <span class="text">1</span>
     <span class="text">2</span>
     <span class="text">3</span>
     <span class="text">4</span>
   </div>
 </body>
</html>

以这个页面为基础,比如我想获取第一个classtext的内容,写法如下

let element=document.querySelector('.text').textContent;
console.log(element); //1

运行代码

按照预期,输出的内容是1,是我想要的结果

页面中有多个classtest的元素,但是精准的返回了我们要想的1,是因为该方法只会匹配页面中查到的第一个元素

实例2

还用上面的页面为例,如果我想获取到页面中第二个classtext的元素该怎么写呢。

let element=document.querySelector('span.text:nth-child(2)').textContent;
console.log(element); //2

运行代码

该方法支持复杂选择器

实例3

页面元素中id应该是唯一的,但是在实际开发中很有可能会出现一个页面中有多个相同id的元素,那这个时候使用这个方法会得到什么呢。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <span id="first">1</span>
    <span id="first">2</span>
  </body>
</html>

页面中有两个idfirst的元素,我们执行该方法看一下效果

let element=document.querySelector('#first').textContent;
console.log(element); //1

返回结果是1 运行代码

就算页面中有多个id重复的元素,也是返回第一个元素

document.querySelectorAll()

返回与指定的选择器组匹配的文档中的元素列表。

语法

let elementList = document.querySelectorAll(selectors);

参数

  • selectors

这个字符串必须是一个合法的 CSS选择器字符串

如果selectors参数中包含 CSS伪元素,则返回的列表始终为空。

返回值

一个静态 NodeList,包含一个与至少一个指定选择器匹配的元素的Element对象,或者在没有匹配的情况下为空NodeList

实例

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <div class="first">
      <span class="text">1</span>
      <span class="text">2</span>
      <span class="text">3</span>
      <span class="text">4</span>
    </div>
  </body>
</html>


 let elementList = document.querySelectorAll('.text');
console.log(elementList) // [object NodeList] (4)

document.images

返回当前文档中所有 image 元素的集合.

语法

let imageCollection = document.images;

返回值

HTMLImageElement集合,当前页面的所有图片元素

实例

let ilist = document.images;
for(var i = 0; i < ilist.length; i++) {
    if(ilist[i].src == "logo.png") {
        
    }
}