uniapp获取dom节点的方法:1、通过“let dom=query.select(selector)”方法获取匹配选择器的第一个节点;2、使用“letdoms=query.selectAll(selector)”方法获取所有节点。
本教程操作环境:windows7系统、uni-app2.5.1版本、thinkpad t480电脑。
推荐(免费):uni-app开发教程
uni-app 获取DOM 节点
【参考官网:https://uniapp.dcloud.io/api/ui/nodes-info?id=selectorqueryexec】
一、如何获取SelectorQuery对象实例:
let query=uni.createSelectorQuery();
功能:返回一个SelectorQuery对象的实例,该实例用来查询DOM节点的信息。
注意事项:
(1)该方法需要在生命周期mounted后进行调用。
(2)nvue技术不支持该方法。
二、如何获取DOM节点:
1、获取匹配选择器的第一个节点:
let dom=query.select(selector)
2、获取匹配选择器的所有节点:
letdoms=query.selectAll(selector)
上述两个方法均返回NodesRef对象实例,该实例用来获取DOM节点的信息。
三、如何获取DOM节点的信息:(以doms为例)
1、获取DOM节点的布局位置信息:
doms.boundingClienRect(function(res){ //res:{left,top,right,bottom,width,height} }).exec(function(){ //上述布局位置信息获取成功后执行的回调函数 })
2、获取DOM节点的滚动位置信息:
doms.scrollOffset(function(){ //res:{scrollLeft,scrollTop} }).exec(function(){ //上述滚动位置信息获取成功后执行的回调函数 })
3、获取DOM节点的所有信息:
doms.fields({ rect:true, //是否返回节点布局位置信息{left,top,right,bottom} size:true, //是否返回节点尺寸信息{width,height} scrollOffset:true //是否返回节点滚动信息{scrollLeft,scrollTop} },function(res){ //res 可以返回第一个参数对象中指定为true的相关信息 }).exec(function(){ //上述节点信息获取成功后执行的回调函数 })
四、代码实例
1、例1: d477f9ce7bf77f53fbcf36bec1b69b7a中有多个类名为leftItem的节点,如何获取这些节点距离顶部的距离,并将这些距离赋给一个在数据区已经定义好的名为leftItemTop的数组。
uni.createSelectorQuery().selectAll(".leftItem").boundingClienRect(res=>{ this.leftItemTop=res.map(item=>item.top) }).exec(()=>{ console.log(this.leftItemTop) })
2、例2:cf02b64373d56bfa6005cf61bdd2cdf0中有多个类名为rightItem的节点,如何获取这些节点的高度,并将这些高度赋值给一个在数据区已经定义好的名为rightItem的数组。
uni.createSelectorQuery().selectAll(".rightItem").fields({ size:true },res=>{ this.rightItemHeight=res.map(item=>{item.height}) }).exec(()=>{ console.log(this.rightItemHeight) })
五、数据渲染DOM造成的异步问题:
【参考官网:https://cn.vuejs.org/v2/api/#vm-nextTick】
【推荐阅读:https://segmentfault.com/a/1190000012861862】
**问题:**某个数据区的变量temp讲影响DOM结构的渲染,且规定该变量更新后直到DOM结构重新渲染完成后还需要做一个其他的操作,则这些其他的操作如何保证在DOM结构重新渲染完成后才发生?
解决方案:这些需要DOM结构重新渲染完成后才发生的操作必须写在this&nextTick(function(){})格式的回调函数中。
<block v-for="(item,index) in domData"> <view class="domItem">{{item.title}}</view> </block>
我们就说上述结构是基于数据domData驱动的结构,变量domData需要先从接口中获取必要的数据,再渲染到DOM结构中。
data(){ return{ domData:[], //用于储存从接口中获取的DOM数据 domItemWidth:[] //用于储存获取的DOM结构的宽度 } }
当变量domData从接口中得到数据后,还必须保证成功渲染了DOM结构之后,才能去获取这些结构的宽度,因此要将后续的操作用this.nextTick(function(){})包裹起来 ,既书写在this.nextTick(function(){})的回调函数内部。
上述事例的代码如下:
uni.request({ url:"http://localhost:8080/......", data:{.....}, success:res=>{ this.domData=res.data; this.nextTick(()=>{//该格式保证了domData已经得到接口数据并成功渲染DOM结构 uni.createSelectorQuery().selectAll(".domItem").fields({ size:true },res=>{ this.domItemWidth=res.map(item=>item.width) }).exec(()=>{ console.log(this.domItemWidth) }) }) } })
以上是uniapp如何获取dom节点的详细内容。更多信息请关注PHP中文网其他相关文章!

本文讨论了有关移动和网络平台的调试策略,突出显示了Android Studio,Xcode和Chrome DevTools等工具,以及在OS和性能优化的一致结果的技术。

文章讨论了用于Uniapp开发的调试工具和最佳实践,重点关注Hbuilderx,微信开发人员工具和Chrome DevTools等工具。

本文讨论了跨多个平台的Uniapp应用程序的端到端测试。它涵盖定义测试方案,选择诸如Appium和Cypress之类的工具,设置环境,写作和运行测试,分析结果以及集成

本文讨论了针对Uniapp应用程序的各种测试类型,包括单元,集成,功能,UI/UX,性能,跨平台和安全测试。它还涵盖了确保跨平台兼容性,并推荐Jes等工具

本文讨论了UNIAPP开发中的共同绩效抗模式,例如过度的全球数据使用和效率低下的数据绑定,并提供策略来识别和减轻这些问题,以提高应用程序性能。

本文讨论了通过压缩,响应式设计,懒惰加载,缓存和使用WebP格式来优化Uniapp中的图像,以更好地进行Web性能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

WebStorm Mac版
好用的JavaScript开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中