简体中文
返回一个匹配特定 ID 的元素, 如果不存在,返回 null。
如果需要获取指定的节点类型,需要使用 as 进行类型转换。
ID 区分大小写,且应该是唯一的。如果存在多个匹配的元素,则返回第一个匹配的元素。
Web | 微信小程序 | Android | iOS | iOS uni-app x UTS 插件 |
---|---|---|---|---|
4.0 | 4.41 | 3.91 | 4.11 | 4.25 |
注意:
uni是全局api,本方法获取的元素,是页面栈栈顶(不包括 dialogPage)的页面的元素,而不是执行本方法代码所在的页面的元素。
如果A页面被栈顶的B页面盖住,在A页面执行uni.getElementById
会访问到B页面的元素。
如需寻找特定页面上的Element,应使用UniPage对象的getElementById方法
而获取当前页面对象的方法,则是this.$page
,这个方式可以获取到dialogPage页面,那么通用的、在当前页面获取UniElement的方式是:this.$page.getElementById
另一种与页面绑定的获取元素的方式是this.$refs
获取的组件对象再进一步as为element。详见
名称 | 类型 | 必填 | 默认值 | 兼容性 | 描述 |
---|---|---|---|---|---|
id | string.IDString | string | 是 | - | - | - |
3.93+
支持泛型,可通过 uni.getElementById<ElementType>(id)
获取指定类型的元素。对于组件有自带方法的情况,通过泛型指定具体的元素类型,就可以调用该类型组件的专用方法,比如unicloud-db组件。
具体的组件元素类型,可查阅组件文档/组件类型
获取。
<template>
<view>
<text id='text' ref='textRef'>test text</text>
</view>
</template>
<script>
export default {
onReady(){
uni.navigateTo({
url: '/pages/test/test'
success() {
// 通过 ref 获取指定页面的元素
const textRef = this.$refs['textRef']
// 通过 getElementById 获取指定页面的元素,此时当前页面为 test 页面,所以获取不到 #text 元素
const textNode = uni.getElementById('text')
}
})
}
}
</script>
类型 | 必备 |
---|---|
UniElement | 否 |
Template
Script
<template>
<page-head id="page-head" title="getElementById"></page-head>
<view style="margin: 0 15px;">
<text id="text">this is text</text>
<view id="view" class="uni-common-mt" style="border: 1px solid red">this is view</view>
<button class="uni-btn" @click="changePageHeadBackgroundColor">
修改 page-head 背景色
</button>
<button class="uni-btn" @click="changeTextColor">
修改 text 字体颜色
</button>
<button class="uni-btn" @click="changeViewStyle">
修改 view 宽高及背景色
</button>
<button class="uni-btn" @click="goMultipleRootNode">
跳转多根节点示例
</button>
</view>
</template>
名称 | 类型 | 必备 | 默认值 | 兼容性 | 描述 |
---|---|---|---|---|---|
errMsg | string | 是 | - | 错误信息 |