在JavaScript中可以通过BOM查询html文档中的元素,也就是所谓的在html中获取对象然后对它添加一个函数。

常用的方法有以下几种:

①document.getElementById()    通过元素ID在全局查找元素

②document.getElementsByTagName()    通过元素标签名字在全局查找元素

    element.getElementsByTagName()    通过元素标签在指定元素内部查找元素

③document.getElementsByClassName()    通过元素标签的className在全局查找元素

    element.getElementsByClassName()    通过元素标签的className在指定元素内部查找元素

但是很多实际情况下,用这三种方法不是很方便,很多时候需要多次调用,就晓得有点麻烦,代码量也有点大,所以这个时候我们就需要将查询函数封装成一个函数。这里我们可以参照css包含选择器的特性,给函数传递一串字符串。比如如下所示:

html结构:

传递的参数如下:

 var atrr = $(".box .box1 .div1 span");

然后就是封装函数了。

首先我们需要获取最外层的一个html标签,然后再在这个标签内部去查找我们需要的元素。

var result = document.getElementsByTagName("html");

上面的代码中我们获取了html中最外层的标签<html>标签

然后将接收到的字符串按照空格分隔为一个数组,数组的每个元素为一个className、ID或者标签名。然后接下来就是遍历了。

    当数组元素为className时,我们就需要调用element.getElementsByClassName() 来获取元素

    当数组元素为标签名时,我们就需要调用element.getElementsByTagName() 来获取元素

    当数组元素为ID时,我们就需要调用document.getElementById()  来获取元素

最后当遍历完成的时候,我们也就查找到了我们需要的内容。代码如下:

function $(selector){
var strs = selector.split(" ");//通过空格切割传递的字符串
var result = document.getElementsByTagName("html");//获取最外层的dom元素
for(var i = 0,len = strs.length;i<len;i++){//根据传过来的字符串,一层一层的遍历查找dom
if(strs[i].charAt(0)==="#"){//如果是id,返回的是dom元素
result = document.getElementById(strs[i].slice(1));
}else if(strs[i].charAt(0)==="."){//如果是class,则返回的是一个伪数组(集合),需要加一个下标,才能获得dom
result = byClass(strs[i].slice(1),result[0]);
}else{//如果是tagName
if(i===0)//代表传递的字符串只有一个tagName,
result = result[0].getElementsByTagName(strs[i]);
else

更多内容请见原文,文章转载自:https://blog.csdn.net/weixin_44519496/article/details/118567825

最新文章

  1. Oracle备库TNS连接失败的分析
  2. 了不起的Node.js: 将JavaScript进行到底(Web开发首选,实时,跨多服务器,高并发)
  3. OpenLayers中地图缩放级别的设置方法
  4. java学习_文件工具类
  5. OLE-Excel基本操作
  6. 【mongodb】 需求
  7. C# WCF学习笔记(二)终结点地址与WCF寻址(Endpoint Address and WCF Addressing) WCF中的传输协议
  8. WCF 配置服务 (02)
  9. python中的对象拷贝
  10. UESTC_韩爷的情书 2015 UESTC Training for Graph Theory&lt;Problem H&gt;
  11. 深入浅出 Java Concurrency 锁机制 : AQS
  12. 每次打开VS都报错:我们无法自动填充你的 Visual Studio Team Services 帐户
  13. ubuntu-17.10 安装 FANN
  14. 关于数据库timestamp类型问题
  15. 十三.iptabled配置
  16. Linux mint 下开发设置
  17. Spring MyBatis多数据源(同包)
  18. Docker学习笔记1 -- 刚入手docker时的几个命令
  19. 【391】栈与队列,Python实现
  20. PHP开发——变量

热门文章

  1. Redis 缓存击穿(失效)、缓存穿透、缓存雪崩怎么解决?
  2. maven jar包冲突问题
  3. el-table高度问题
  4. AcWing 165. 小猫爬山 DFS
  5. 2021.08.16 P1078 文化之旅(最短路)
  6. 如何使用 pyqt 实现 Groove 音乐播放器
  7. XCTF练习题---WEB---view_source
  8. C#关于在返回值为Task方法中使用Thread.Sleep引发的思考
  9. Node.js躬行记(19)——KOA源码分析(上)
  10. 【mq】从零开始实现 mq-10-消费者拉取消息回执 pull message ack