首页
学习
活动
专区
圈层
工具
发布

DOM 元素的循环遍历

博客地址:https://ainyi.com/89 获取 DOM 元素的几种方式 get 方式: getElementById getElementsByTagName getElementsByClassName...(每个dom元素) query 方式 query 方式获取的 dom 元素,可使用==forEach、for-in、for-of、for==循环 forEach、for-of、for 循环的结果无差别...,少了 ƒ namedItem() { native code },多了 Object 的几个方法 这说明,query 方式获取的 dom 元素集合,可执行 Object 对应的方法,但没有 namedItem...:递归的运行效率没有迭代的运行效率高,一般都需要把递归的循环优化成迭代的循环 所以上面递归算法可以进一步优化 优化深度优先遍历 使用 NodeIterator 对象,可以对 DOM 树进行深度优先的搜索...创建 NodeIterator 对象,需要使用 document 对象的 createNodeIterator 方法,该方法接收四个参数: root:搜索开始的节点 whatToShow:一个数值代码

7.7K60

vue 获取 DOM 元素的方法

1 .原生js获取 DOM 节点 document.querySelector(选择器) document.getElementById(id选择器) document.getElementsByClassName...(class选择器) .... 2. vue2中获取当前组件的实例对象 因为每个 vue 的组件实例上,都包含一个 refs 对象,里面存储着对应的 DOM 元素或组件的引用。...所以在默认情况下, 组件的 refs 指向一个空对象 。 可以先在组件上加上 ref="名字" ,然后通过 this.$refs.名字 获取相应元素并进行操作。...$refs.divDom.style.color='yellow' //引用到组件的实例之后,也可以调用组件上的 methods方法 this....$refs.but.click(); }, }, } 3.vue3中获取当前组件的实例对象 1.创建 ref 变量,给组件或元素绑定 ref 属性值为该变量 2.

6.3K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    DOM节点和元素之间的区别是什么?

    文档对象模型(DOM)是将 HTML 或 XML 文档视为树结构的接口,其中每个节点(node)都是文档的对象。DOM 还提供了一组用于查询树、修改结构和样式的方法。...DOM 还使用了术语 元素(element):它与节点非常相似。那么 DOM 节点和元素之间有什么区别呢? DOM 节点 要理解它们区别,关键是理解节点是什么。...: document.nodeType === Node.DOCUMENT_NODE; // => true DOM元素 掌握了DOM节点的知识之后,现在该区分 DOM 节点和元素了。...如果你理解了什么事节点,那么答案很明显:元素是特定类型的节点——Node.ELEMENT_NODE以及文档、注释、文本等类型。 简单的说,元素是使用 HTML 文档中的标记编写的节点。...DOM属性:节点和元素 除了区分节点和元素外,还需要区分仅包含节点或仅包含元素的 DOM 属性。

    3.2K20

    浏览器 DOM 元素的事件代理指的是什么

    // 每日前端夜话 第424篇 // 正文共:1400 字 // 预计阅读时间:7 分钟 事件 在网页中,如果想与使用者进行“互动”,必须要通过某种方法知道他都做了什么。...当然,浏览器开发者们早已根据 W3C 事件规范[1]实现好了底层的逻辑,我们只需要通过 Web API 中的 DOM Event[2],通过注册想监听的 DOM 元素和事件的事件监听器(Event Listener...规范中定义了时间传递的三个阶段: 捕获阶段:由 DOM Tree 的根节点依次向内传递,过程中触发各别元素的捕获阶段事件监听。...如图所示,当使用者触发一个DOM 元素的事件时,首先会进入捕获阶段(Capture Phase),从根结点逐步向事件目标传递;到达目标后则进入目标阶段(Target Phase),接着就开始折返,进入向根结点传递的冒泡阶段...库和框架中的事件处理 在 DOM 事件处理的这部分,jQuery 和 Vue 都将原生的事件监听器做了封装,方便我们快速设定、使用,甚至会自动帮你移除无用的事件监听。

    1.4K30

    vue操作dom元素的三种方法

    1.原生js操作dom const dom = getElementById(‘box’) 2.vue官方方法:ref vue中的ref是把当前dom元素 “ 抽离出来 ” ,只要通过 this....$refs就可以获取到 .set是我们要操作的dom对象,它的ref是 up @click=“Alert” 给父元素一个点击事件, 接下来我们来编写这个方法...,jQuery 操作dom,看完以后直呼不敢用 3.jQuery操作dom   只要拿jQuery的选择器,选中相应的dom进行操作就可以了,但是大家都知道jQuery获取元素是查找页面所有,相当于“循环...”所有元素直至找到需要的dom,但是vue是单页面的,jQuery获取dom并不只是获取vue当前页面,而是从根路由开始查找所有,当其他页面出现相同的元素,也会被获取到,而且jQuery操作的dom,如果是根据动态获取数据渲染的...,那么写在mounted里的操作方法将会失效,必须放到updated里,这样会导致有些操作被执行多遍,所以还是不建议在vue中使用jQuery。

    2.8K20

    jquery中dom元素的attr和prop方法的理解

    一、背景   在编写使用高版本[ jQuery 1.6 开始新增了一个方法 prop()]的jquery插件进行编写js代码的时候,经常不知道dom元素的attr和prop方法到底有什么区别?...也是W3C里本身就包含的几个属性,换句话说是IDE中能够自动提示的属性,这些属性就被称为dom元素的固有属性,这种情况下,我建议使用prop方法。   ....那么很明显前两个是该dom元素的固有属性,最后一个是我们自己定义的属性。...a标签中的固有属性中并不包含该属性。这些属性被称为dom元素的自定义属性,这种情况下,我建议使用attr方法。此时若使用prop方法进行设置和获取该属性的值时就会返回undefined值。   ...、radio、select等元素的选中属性"checked"和"selected",这些属性也是dom元素的固有属性,因此使用prop方法才能正确的进行获取和设置。

    2K20

    如何正确遍历删除List中的元素(普通for循环、增强for循环、迭代器iterator、removeIf+方法引用)

    遍历删除List中符合条件的元素主要有以下几种方法: 普通for循环 2.增强for循环 foreach 3.迭代器iterator 4.removeIf 和 方法引用 (一行代码搞定) 其中使用普通for...所以推荐使用迭代器iterator,或者JDK1.8以上使用lambda表达式进行List的遍历删除元素操作。...以下是上述几种方法的具体分析: 普通for循环 /** * 普通for循环遍历删除元素 */ List students = this.getStudents();...,注意要使用迭代器的remove方法,而不是List的remove方法。...使用removeIf和方法引用删除List中符合条件的元素: List urls = this.getUrls(); // 使用方法引用删除urls中值为"null"的元素 urls.removeIf

    14.4K41

    Github的正确使用方法

    在了解了Git的基本用法后(如果你还未了解 Git 的基本使用方法,建议你先话点时间阅读下《 Pro Git 》这本书),相信你已经开始跃跃欲试了,那么我就说下如何正确的使用 Github。...下面的图描述了使用 Github 的基本流程: ? 第一步:Fork项目 Fork 项目其实就是在 Github 上拷贝一份他人项目的副本作为自己的项目。...一般来说使用 SSH 模式,在一次配置后,就可以免输密码提交代码,比较方便,但使用 HTTPS 模式更具备通用性,所以各有利弊,随意选择~ # 使用 ssh clone 项目到本地$ git clone...git@github.com:rvm/rvm.git# 使用 https clone 项目到本地$ git clone https://github.com/rvm/rvm.git 第三步:创建分支...需要注意的是 Commit 代码必须给出简明扼要的提交信息,下面是一个范本,第一行是不超过50个字的提要,然后空一行,罗列出改动原因、主要变动、以及需要注意的问题。

    6.1K30

    遍历ArrayList,并删除某些元素的方法实现「建议收藏」

    题目:一个ArrayList对象aList中存有若干个字符串元素,现欲遍历该ArrayList对象,删除其中所有值为”abc”的字符串元素,请用代码实现。...} System.out.println(aList); } } 输出结果为:[a, ab, abcr, abcf, abdc] 也可以使用迭代器来遍历...然而使用迭代器,答案是对的,所有的“abc”都被移除掉了。 出现这种情况的原因是什么呢?...因为ArrayList底层的数据结构是数组, 对于数组的特性,我们都知道, 如果删除其中某个元素的话,那么该元素后面的所有元素都会前移一个位置,结合这个特性,回到刚才的for循环中,就能很好的解释为什么漏删一条...hasNext()方法,原理是指针向后移动,每运行一次it.next(),指针向后移动一次,一个一个的遍历。

    73720

    【Web APIs】DOM 文档对象模型 ③ ( 根据类名获取 DOM 元素 - getElementsByClassName 函数 | 代码示例 )

    1、根据类名获取 DOM 元素 - getElementsByClassName 函数 根据类名获取 DOM 元素 , 需要 使用 HTML5 新增的方法 , Document.getElementsByClassName...函数获取 ; HTML5 必须是 IE9.0 以上的版本才能使用 ; 注意兼容性 : 如果要开发的网页需要兼容老版本的浏览器 , 如 : IE 678 版本 , 则不能使用该方法 ; Document.getElementsByClassName...(className); Element.getElementsByClassName 函数 是 获取 Element 元素下的所有 指定类名的 DOM 元素 , 返回结果也是 HTMLCollection...// 控制台打印获取结果 console.log(elements); // 遍历 HTMLCollection 中封装的 DOM 元素 for (var...("box"); // 控制台打印获取结果 console.log(elements); // 遍历 HTMLCollection 中封装的 DOM

    71410

    认识虚拟 DOM

    它也是 HTML 元素基于对象的表示(推荐这篇神奇的Shadow DOM,能更好的理解影子 DOM),影子 DOM 能把 DOM 分离成更小封装位,并且能够跨 HTML 文档使用。...为此,我们需要使用 DOM API 来查找我们想要更新的元素,创建新元素,添加属性和内容,然后最终更新 DOM 元素本身。...举例一些简单的方法,比如 document.getElementsByClassName() 可以小规模使用,但如果每秒更新很多元素,这非常消耗性能。...的原理 现在我们已经知道了虚拟 DOM 是什么,但它是如何解决操作 DOM 的性能问题呢?...一旦收集了所有差异,我们就可以批量更改 DOM,并只做所需的更新。 例如,我们可以循环遍历每个差异,并根据 diff 指定的内容添加新的子代或更新旧的子代。

    89020

    动态生成DOM元素的高度及行数获取与计算方法

    背景 在开发IM的项目过程中,经常会有出现一些需要计算DOM高度,然后超出若干行隐藏等需求。很多时候,需要计算高度的DOM元素都是动态生成的,我们无法在数据渲染前获取到它的高度。...但是,如果我们需要获取到这段在内存中未渲染的动态文本,也能够通过如下几个方法。...遍历后赋值给新容器 }); node.innerHTML = html; document.body.appendChild(node);//需要将新容器挂载到DOM中,浏览器才会进行高度计算...方案再优化 利用现有DOM容器 使用cloneNode方法来对现有的容器进行clone,我们可以省去输入样式的麻烦,同时能够精确保证两个容器完全一致。...为什么我们不使用display:none来实现上述效果呢?因为在使用了该属性后,window.getComputedStyle获取的高度将变为auto。

    4.6K30

    Arch Linux的正确使用方法

    查看自己的内存使用情况, LXDE + 32 位的 Arch Linux,我的内存占用才 70 M 左右,我知道我这次找到了真爱,于是一直使用 Arch 至今,也感谢我的电脑配置低,不然我很可能就停留在...archlinux安装后没有ifconfig命令 问:很多和网络有关的命令都没有,ifconfig,route ,nslookup这些都没有,变量没设置错误,用root也找不到,这是什么原因呢?...若要一次性安装 Fcitx 主程序和相关的模块,可使用此命令: pacman -S fcitx-im 使用 FCITX 之前,必须先进行一些环境设定: 如果采用 KDM、GDM、LightDM 等显示管理器...要使mplayer正确显示字幕,关键是要使字幕文件的编码和mplayer config里使用的编码相一致。...如果字幕文件编码为utf-8,而设置成subcp=cp936,则会出现部分乱码的情况。另一种更为简单的方法是设置成subcp=enca:zh:ucs-2,由enca负责字幕的编码显示问题。

    6.5K70

    【Groovy】集合遍历 ( 使用 for 循环遍历集合 | 使用集合的 each 方法遍历集合 | 集合的 each 方法返回值分析 )

    文章目录 一、使用 for 循环遍历集合 二、使用 each 方法遍历集合 三、集合的 each 方法返回值分析 四、完整代码示例 一、使用 for 循环遍历集合 ---- 使用 for 循环 , 遍历集合...print i + " " } println "" 执行结果 : 1 2 3 二、使用 each 方法遍历集合 ---- 调用集合的 each...调用集合的 each 方法遍历 // 使用集合的 each 方法进行遍历 // 传入的闭包参数 , 就是循环体内容 // 闭包中的 it 参数 , 就是当前正在遍历的元素本身...方法返回值分析 ---- 使用新的集合变量接收 集合 each 方法的返回值 , 如果修改该变量的值 , 则原集合的值也会跟着改变 , 说明 each 方法返回的集合就是原来的集合 ; 代码示例 :...调用集合的 each 方法遍历 // 使用集合的 each 方法进行遍历 // 传入的闭包参数 , 就是循环体内容 // 闭包中的 it 参数 , 就是当前正在遍历的元素本身

    4.8K20

    避免 SSH 干扰循环输入:正确遍历 hosts 文件的多种方法

    一个常见的做法是使用 while read 循环读取 hosts.txt 文件中的 IP 地址,并逐个执行远程命令。 然而,看似简单的脚本却可能“只执行第一台主机”,后续主机被跳过。...本文将深入剖析这一问题的根本原因,并提供多种安全可靠的解决方案,包括使用文件描述符重定向等高级技巧。...一、问题重现 假设我们有如下主机列表文件: $ cat hosts.txt 192.168.0.18 192.168.0.19 192.168.0.15 编写一个简单的遍历脚本: #!...❌ 缺点:不够健壮,存在词法分割风险 ✅ 推荐指数:⭐⭐⭐☆☆ 四、最佳实践建议 推荐方案 五、总结 •while read 未能遍历所有行,根本原因是 ssh 抢占了 stdin•解决方案的核心是:隔离...ssh 与循环的输入流•推荐使用 ssh -n,简单高效•高级场景可使用 read -u 3 + 3<file 实现完全隔离 掌握这些技巧,不仅能解决主机遍历问题,还能避免在其他涉及 ssh、sudo

    16610
    领券