Skip to main content
Version: 3.x

NodesRef

用于获取 WXML 节点信息的对象

参考文档

方法#

boundingClientRect#

添加节点的布局位置的查询请求。相对于显示区域,以像素为单位。其功能类似于 DOM 的 getBoundingClientRect。返回 NodesRef 对应的 SelectorQuery

参考文档

(callback?: BoundingClientRectCallback) => SelectorQuery
参数类型说明
callbackBoundingClientRectCallback回调函数,在执行 SelectorQuery.exec 方法后,节点信息会在 callback 中返回。

示例代码#

示例 1#
Taro.createSelectorQuery().select('#the-id').boundingClientRect(function(rect){
rect.id // 节点的ID
rect.dataset // 节点的dataset
rect.left // 节点的左边界坐标
rect.right // 节点的右边界坐标
rect.top // 节点的上边界坐标
rect.bottom // 节点的下边界坐标
rect.width // 节点的宽度
rect.height // 节点的高度
}).exec()
##### 示例 2
Taro.createSelectorQuery().selectAll('.a-class').boundingClientRect(function(rects){
rects.forEach(function(rect){
rect.id // 节点的ID
rect.dataset // 节点的dataset
rect.left // 节点的左边界坐标
rect.right // 节点的右边界坐标
rect.top // 节点的上边界坐标
rect.bottom // 节点的下边界坐标
rect.width // 节点的宽度
rect.height // 节点的高度
})
}).exec()

API 支持度#

API微信小程序H5React Native
NodesRef.boundingClientRect✔️✔️

context#

添加节点的 Context 对象查询请求。目前支持 VideoContextCanvasContextLivePlayerContextEditorContextMapContext 的获取。

参考文档

(callback?: ContextCallback) => SelectorQuery
参数类型说明
callbackContextCallback回调函数,在执行 SelectorQuery.exec 方法后,返回节点信息。

示例代码#

Taro.createSelectorQuery().select('.the-video-class').context(function (res) {
console.log(res.context) // 节点对应的 Context 对象。如:选中的节点是 <video> 组件,那么此处即返回 VideoContext 对象
}).exec()

API 支持度#

API微信小程序H5React Native
NodesRef.context✔️

fields#

获取节点的相关信息。需要获取的字段在fields中指定。返回值是 nodesRef 对应的 selectorQuery

注意 computedStyle 的优先级高于 size,当同时在 computedStyle 里指定了 width/height 和传入了 size: true,则优先返回 computedStyle 获取到的 width/height。

参考文档

(fields: Fields, callback?: FieldsCallback) => SelectorQuery
参数类型说明
fieldsFields
callbackFieldsCallback回调函数

示例代码#

Taro.createSelectorQuery().select('#the-id').fields({
dataset: true,
size: true,
scrollOffset: true,
properties: ['scrollX', 'scrollY'],
computedStyle: ['margin', 'backgroundColor'],
context: true,
}, function (res) {
res.dataset // 节点的dataset
res.width // 节点的宽度
res.height // 节点的高度
res.scrollLeft // 节点的水平滚动位置
res.scrollTop // 节点的竖直滚动位置
res.scrollX // 节点 scroll-x 属性的当前值
res.scrollY // 节点 scroll-y 属性的当前值
// 此处返回指定要返回的样式名
res.margin
res.backgroundColor
res.context // 节点对应的 Context 对象
}).exec()

API 支持度#

API微信小程序H5React Native
NodesRef.fields✔️✔️

node#

获取 Node 节点实例。目前支持 Canvas 的获取。

参考文档

(callback?: NodeCallback) => SelectorQuery
参数类型说明
callbackNodeCallback回调函数,在执行 SelectorQuery.exec 方法后,返回节点信息。

示例代码#

Taro.createSelectorQuery().select('.canvas').node(function(res){
console.log(res.node) // 节点对应的 Canvas 实例。
}).exec()

API 支持度#

API微信小程序H5React Native
NodesRef.node✔️

scrollOffset#

添加节点的滚动位置查询请求。以像素为单位。节点必须是 scroll-view 或者 viewport,返回 NodesRef 对应的 SelectorQuery

参考文档

(callback?: ScrollOffsetCallback) => SelectorQuery
参数类型说明
callbackScrollOffsetCallback回调函数,在执行 SelectorQuery.exec 方法后,节点信息会在 callback 中返回。

示例代码#

Taro.createSelectorQuery().selectViewport().scrollOffset(function(res){
res.id // 节点的ID
res.dataset // 节点的dataset
res.scrollLeft // 节点的水平滚动位置
res.scrollTop // 节点的竖直滚动位置
}).exec()

API 支持度#

API微信小程序H5React Native
NodesRef.scrollOffset✔️✔️

参数#

BoundingClientRectCallback#

回调函数,在执行 SelectorQuery.exec 方法后,节点信息会在 callback 中返回。

(result: BoundingClientRectCallbackResult) => void
参数类型
resultBoundingClientRectCallbackResult

BoundingClientRectCallbackResult#

参数类型说明
bottomnumber节点的下边界坐标
datasetRecord<string, any>节点的 dataset
heightnumber节点的高度
idstring节点的 ID
leftnumber节点的左边界坐标
rightnumber节点的右边界坐标
topnumber节点的上边界坐标
widthnumber节点的宽度

ContextCallback#

回调函数,在执行 SelectorQuery.exec 方法后,返回节点信息。

(result: ContextCallbackResult) => void
参数类型
resultContextCallbackResult

ContextCallbackResult#

参数类型说明
contextRecord<string, any>节点对应的 Context 对象

Fields#

参数类型必填说明
computedStylestring[]指定样式名列表,返回节点对应样式名的当前值
contextboolean是否返回节点对应的 Context 对象
datasetboolean是否返回节点 dataset
idboolean是否返回节点 id
markboolean是否返回节点 mark
nodeboolean是否返回节点对应的 Node 实例
propertiesstring[]指定属性名列表,返回节点对应属性名的当前属性值(只能获得组件文档中标注的常规属性值,id class style 和事件绑定的属性值不可获取)
rectboolean是否返回节点布局位置(left right top bottom
scrollOffsetboolean否 是否返回节点的 scrollLeft scrollTop,节点必须是 scroll-view 或者 viewport
sizeboolean是否返回节点尺寸(width height

FieldsCallback#

回调函数

(res: Record<string, any>) => void
参数类型说明
resRecord<string, any>节点的相关信息

NodeCallback#

回调函数,在执行 SelectorQuery.exec 方法后,返回节点信息。

(result: NodeCallbackResult) => void
参数类型
resultNodeCallbackResult

NodeCallbackResult#

回调函数

参数类型说明
nodeRecord<string, any>节点对应的 Node 实例

ScrollOffsetCallback#

回调函数,在执行 SelectorQuery.exec 方法后,节点信息会在 callback 中返回。

(result: ScrollOffsetCallbackResult) => void
参数类型
resultScrollOffsetCallbackResult

ScrollOffsetCallbackResult#

参数类型说明
datasetRecord<string, any>节点的 dataset
idstring节点的 ID
scrollLeftnumber节点的水平滚动位置
scrollTopnumber节点的竖直滚动位置

API 支持度#

API微信小程序H5React Native
NodesRef.boundingClientRect✔️✔️
NodesRef.context✔️
NodesRef.fields✔️✔️
NodesRef.node✔️
NodesRef.scrollOffset✔️✔️