首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何更优地去创建DOM元素

本文作者:IMWeb yuchenli 原文出处:IMWeb社区 未经同意,禁止转载 如何更优地去创建DOM元素 创建DOM元素是最为基本的DOM操作,这里先举个栗子 这里先使用createElement...这里简单地通过createElement创建DOM是存在比较严重的性能问题的: 1、createElement本身就是不小的性能开支 2、 每次创建li元素都换插入到DOM中,会引起多次重排和重绘。...innerHTM 对面上面那种问题,可能就会想到通过innterHTML方式去创建DOM元素 这里先举个栗子: var str = ''; for (t = 0; t < num; t++) {...cloneNode cloneNode是用于克隆节点的,相比直接调用createElement创建DOM元素而言,它所花费的开销会更小些,就好比:读书的时候,抄作业要比做作业的容易的多。...那么还有没有更快的方式去创建DOM元素呢?接下来先介绍一个东西DocumentFragment DocumentFragment DocumentFragment是示一个没有父级文件的最小文档对象。

2.1K10
您找到你想要的搜索结果了吗?
是的
没有找到

DOM元素定位

, 16 2月 2021 作者 847954981@qq.com 前端学习, 我的编程之路 DOM元素定位 在HTML中有许多如图片等的DOM元素,在网页下拉移动中,DOM元素的位置定位通常通过 position...属性来完成 在一般情况下我们DOM元素的默认position的值为 static 除此之外position还拥有 relative(相对定位) absolute(绝对定位) fixed(固定定位) sticky...,即原本DOM元素下方的元素会向上占住原本DOM元素的位置,类似于网页新开了一个图层的效果。...固定定位 fixed fixed原理很简单,就是讲DOM元素固定在整个页面某一位置不会随着下拉页面而改动,类似一个图层放置在那里。...可以利用如 right:50px 等来调节位置 粘性定位 sticky 这个简单说就是当页面下拉到DOM元素到达了设定的位置,DOM元素将不会再随下拉移动,效果如页面内图片 顺便一提,如前面所说,网页存在类似图层一说

91530

jQuery操作DOM元素

最常见的场景莫过DOM元素操作和前端页面使用AJAX向服务器发送请求。...的标签,返回类型是DOM元素数组 id $('#value'),选取页面上id=value的标签 $('[name]'),选取带有name属性的标签,返回类型是DOM元素数组 $('[name="tag...="tag"]'),选取name不等于tag的标签,返回类型是DOM元素数组 $('[href=".jpg"]'),选取所有href属性值以 ".jpg" 结尾的标签,返回类型是DOM元素数组 --...tr元素,返回类型是DOM元素数组 :odd $("tr:odd"),选取页面上索引为奇数的tr元素,返回类型是DOM元素数组 :not() $("input:not(:empty)"),所有不为空的...+ conditions); 元素操作 说明 hide() 隐藏元素 show() 显示元素 $('') 创建p元素 append() 向元素末尾添加子元素 appendTo

2.6K40

JavaScript 学习-34.HTML DOM 创建插入删除替换元素

前言 HTML DOM 可以创建一个新元素,并插入到指定元素的位置 createElement 创建元素 document.createElement() 可以创建一个元素 document.createTextNode...() 创建一个文本节点 appendChild() 方法可向节点的子节点列表的末尾添加新的子节点。...DocumentFragment 节点代表一个文档的片段,本身就是一个完整的 DOM 树形结构。 它没有父节点,parentNode 返回 null ,但是可以插入任意数量的子节点。...它不属于当前文档,操作 DocumentFragment 节点,要比直接操作 DOM 树快得多。 它一般用于构建一个 DOM 结构,然后再插入当前文档。...添加到div子元素,p标签前面 这是文本内容 // 创建元素节点 btn = document.createElement

2.2K30

DOM概述 选取文档元素

脚本化文档 客户端js的存在使得静态的html文档变成了可交付式的web应用 DOM概述 文档对象(DOM)是表示和操作html和xml文档内容的基础api。 <!...选取文档元素 通过ID选取元素 举一个栗子,通过ID查找多个元素 /* * 函数接收任意多的字符串参数 * 每个参数将当做元素的id传给document.getElementById() * 返回一个对象...("span"); 这样能获取第一个p元素里的所有的span元素 另外document还有两个属性,分别是特殊的body,以及head元素,这两个元素如果源代码未包含,其浏览器会隐式的创建他们,以及documentElement...e.innerHTML; // 返回序列化过的html代码,该方法继承自Element,所有Document对象的方法都基于其,因为同样是document继承来的,所以具有innerHTML方法 } ) // 创建一个数组...,并把该数组的元素传入回调函数中进行处理 注意,保存的不是快照,伴随着html中的DOM的更新,属于实时操作的,这一点灰常有用 如果在一个没有div中的有一个该方法,如果页面动态加载进的div元素,其中的

99060

DOM 元素的循环遍历

博客地址:https://ainyi.com/89 获取 DOM 元素的几种方式 get 方式: getElementById getElementsByTagName getElementsByClassName...('popo') 获取 name 属性为 'popo' 的 dom 元素(若多个元素有相同的 name 属性,返回第一个) for-of、for 循环可获取每个 dom 元素: for(let val...(每个dom元素) for(let i = 0; i < a.length; i++) { console.log(a[i]) } // dom // ......(每个dom元素) query 方式 query 方式获取的 dom 元素,可使用==forEach、for-in、for-of、for==循环 forEach、for-of、for 循环的结果无差别...树进行深度优先的搜索 创建 NodeIterator 对象,需要使用 document 对象的 createNodeIterator 方法,该方法接收四个参数: root:搜索开始的节点 whatToShow

6K60

JavaScript DOM元素尺寸和位置

三大点: 1.获取元素CSS大小 2.获取元素实际大小 3.获取元素周边大小 一.获取元素CSS大小 1.通过style内联获取元素的大小 var box = document.getElementById...总结:以上的三种CSS获取元素大小的方法,只能获取元素的CSS大小,却无法获取元素本身实际的大小。比如加上了内边距、滚动条、边框之类的。...二.获取元素实际大小 1.clientWidth和clientHeight 这组属性可以获取元素可视区的大小,可以得到元素内容及内边距所占据的空间大小。...; 3.增加外边据,无变化; 4.增加滚动条,无变化,不会减小; PS:对于元素大小的获取,一般是块级(block)元素并且以设置了CSS大小的元素较为方便。...如果是内联元素(inline)或者没有设置大小的元素就尤为麻烦,所以,建议使用的时候注意。

2.7K70

dom 元素自定义指令

如果感觉 vue 提供的功能不足够,需要获取 dom 元素进行底层操作,就可以自定义指令 在初始化 vue 实例的时候,参数对象里面可以添加一个 directives 属性,为 vue 增加自定义指令。...例子:实现一个指令 v-focus 作用就是插入了这个指令的 input 会被自动聚焦 实现方式 创建自定义指令 创建vue实例时,directives 属性名不能变 指令名称这里是 focus 可以自己起名字...,不要用大写字母,在 dom 标签使用的时候需要添加 v- 前缀 指令内触发的函数名不能乱起,按固定写就好了,感兴趣可以查文档看看其他函数名 函数接收的第一个参数是元素本身。...directives: { focus: { // 指令的定义,这个 inserted 是固定写法,意思是带有这个指令的 dom 元素被插入的时候,触发这个方法 // 还有其他一些可选写法...v-focus type="text"> 注意:按照官网的Vue自定义指令directives设置Element-UI的el-input输入框获取焦点无法生效,通过查看浏览器解析出的Element-UI的DOM

82320
领券