html组件获得其他组件属性,关于获取小程序组件的dom元素属性(详尽版)

在看本篇以前,期待读者先了解js的document.querySelector 方法,在此不做赘述。

由于微信官方禁止小程序操作dom元素,因而无法像前端一样操作小程序DOM,好在官方提供了API ,

这个api叫做wx.createSelectorQuery(),  官方定义:返回一个 SelectorQuery 对象实例。

这个api的select()方法用于查找元素,类似jq的元素选择器

尔后有boundingClientRect(function(res){})则返回指定元素的DOM属性,res代表元素本身,(百度了boundingClientRect :边界中心)

再之后的exec(function(rect){})则是设置元素属性,rect在这里指的是所有匹配到结果的集合,通过调用that/this.setdata({})可以更改元素dom值,请注意!rect是一个数组集合,想要设置某一个元素,需要给该数组加指定元素的下标!

来个简单demo:

wxml:

111

在这个demo里 我想获取.cont1的高度从而动态调整swiper的高度,因而我给swiper的高度设置了参数swiperHeight

wx.js:

page({

data:{

swiperHeight:0} ,/*由于期待页面加载完毕就显示,所以我放在了onload函数内*/

/**

* 生命周期函数--监听页面初次渲染完成*/onReady:function() {var that = thisconst query=wx.createSelectorQuery();

query.select(\'.cont1\').boundingClientRect(function(res) {//这里返回元素自身的DOM属性

console.log(res);

}).exec(function(rect){

that.setData({

swiperHeight: rect[0].height + 0})//rect返回一个数组,需要使用下标0才能找到

//console.log(s[0].height)

});

},

})

网上听大佬说偶尔会有rect返回为null的意外,昨晚翻遍百度,终于找到了一个解决方法,感谢那位大佬(传送门)

/*原理是使用定时器异步获取dom*/

setTimeout(function() {var query =wx.createSelectorQuery();

query.select(\'.cont1\').boundingClientRect();

query.exec(function(rect) {if (rect === null) return;

that.setData({

swiperHeight: rect .height+ 10})

});

},500)

如果有哪些错误,欢迎指教

以上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值