view.md 2.0 KB
Newer Older
D
DCloud_LXH 已提交
1 2 3 4
## view

<!-- UTSCOMJSON.view.description -->

D
DCloud_LXH 已提交
5 6
<!-- UTSCOMJSON.view.compatibility -->

7
<!-- UTSCOMJSON.view.attribute -->
D
DCloud_LXH 已提交
8

taohebin@dcloud.io's avatar
taohebin@dcloud.io 已提交
9
#### 说明
taohebin@dcloud.io's avatar
taohebin@dcloud.io 已提交
10

W
wanganxp 已提交
11
- 为什么使用`hover-class`?使用 css :active伪类来实现点击态,很容易触发,并且滚动或滑动时点击态不会消失,体验较差。建议使用 `hover-class` 属性来实现。并且App平台目前不支持css伪类。
taohebin@dcloud.io's avatar
taohebin@dcloud.io 已提交
12 13


D
DCloud_LXH 已提交
14 15
<!-- UTSCOMJSON.view.event -->

16 17
<!-- UTSCOMJSON.view.component_type-->

DCloud-yyl's avatar
DCloud-yyl 已提交
18
#### App平台@app
19 20
- HBuilder4.0以下版本`hover-class`属性App端与微信小程序效果一样,手指按下进入`hover-class`状态后,手指移动就会取消`hover-class`状态
- HBuilder4.0及以上版本App端调整为手指在view范围内移动不会取消`hover-class`状态,手指移动到view范围之外才会取消`hover-class`状态
21 22 23 24 25 26


#### 如何获取原生view对象

**Android 平台:**

27 28
获取view组件对应的UniElement对象,通过UniElement对象的[getAndroidView](../dom/unielement.md#getandroidview-2)函数获取组件原生view对象

29 30 31 32 33 34 35 36 37 38 39 40 41 42
```uts
//导入安卓原生ViewGroup对象
import ViewGroup from "android.view.ViewGroup"

//通过view组件定义的id属性值,获取view标签的UniElement对象
const viewElement = uni.getElementById(id)
//UniElement.getAndroidView设置泛型为安卓底层ViewGroup对象, 直接获取ViewGroup 如果泛型不匹配会返回null
if(viewElement != null) {
	//viewGroup就是view组件对应的原生view对象
	const viewGroup = viewElement.getAndroidView<ViewGroup>()
}
```

更多示例请参考 uts 插件 [uts-get-native-view](https://gitcode.net/dcloud/hello-uni-app-x/-/blob/alpha/uni_modules/uts-get-native-view/utssdk/app-ios/index.uts)
taohebin@dcloud.io's avatar
taohebin@dcloud.io 已提交
43

DCloud-yyl's avatar
DCloud-yyl 已提交
44
<!-- UTSCOMJSON.view.children -->
taohebin@dcloud.io's avatar
taohebin@dcloud.io 已提交
45

46 47
<!-- UTSCOMJSON.view.example -->

D
DCloud_LXH 已提交
48 49 50
<!-- UTSCOMJSON.view.reference -->

view是Drawable的组件,也就是可以在view上调用绘制API自绘内容。它类似canvas,但不需要单独的canvas组件,在view上就可以直接draw。[详见](../dom/drawablecontext.md)