Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-zh
提交
66297315
unidocs-zh
项目概览
DCloud
/
unidocs-zh
通知
3200
Star
106
Fork
813
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
94
列表
看板
标记
里程碑
合并请求
70
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
unidocs-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
94
Issue
94
列表
看板
标记
里程碑
合并请求
70
合并请求
70
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
66297315
编写于
1月 05, 2023
作者:
杜庆泉
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
uts 组件文档 基本版本
上级
db582c62
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
236 addition
and
103 deletion
+236
-103
docs/plugin/uts-component.md
docs/plugin/uts-component.md
+236
-103
未找到文件。
docs/plugin/uts-component.md
浏览文件 @
66297315
...
...
@@ -17,204 +17,232 @@
### 2.1 UTS组件简介
组件是一种独立,可复用的UI单元,方便单独封装和承担一定的代码逻辑,组件化有利于降低项目的工程复杂度,提升可维护性
UTS组件,即:使用UTS语言在uni平台进行组件开发的技术。
[
关于UTS
](
https://uniapp.dcloud.net.cn/plugin/uts-plugin.html
)
UTS组件,即:使用UTS语言在uni平台进行组件开发的技术。
[
UTS的更多介绍
](
https://uniapp.dcloud.net.cn/plugin/uts-plugin.html
)
组件是一种独立,可复用的UI单元,用于单独封装和承担一定的代码逻辑,组件化可以降低项目的工程复杂度,提升可维护性
UTS组件约定上采用了类Vue组件的语法,
[
Vue组件的更多介绍
](
https://cn.vuejs.org/guide/essentials/component-basics.html
)
,但是具体的约定上会有定制,具体参考第四章节。
UTS组件整体采用了类Vue组件的语法,
[
关于Vue组件
](
https://cn.vuejs.org/guide/essentials/component-basics.html
)
,但是具体的函数上会有定制,具体参考第四章节。
### 2.2 UTS组件和Vue组件差异
UTS组件,与Vue组件区别在于,它秉承了UTS的跨平台特性,统一的UTS语法,各终端不同的本地产出物。
### 2.2 UTS组件优势
UTS组件的优势在于,它秉承了UTS的跨平台特性,统一的UTS语法,各终端不同的本地产出物。
在Android平台会被编译为会被渲染为Android原生View实例,IOS或其他终端平台也是如此。
| |Vue组件 |uts
插件
|
|:------ |:------- |:--------|
|开发语言 |js/ts |uts|
|组件载体 |WebView内部标签 |
编译时生成原生View对象
|
| |Vue组件 |uts
组件 |uni原生组件
|
|:------ |:------- |:--------
|:--------
|
|开发语言 |js/ts |uts
|java/object-c
|
|组件载体 |WebView内部标签 |
系统原生View对象 |系统原生View对象
|
## 3 如何开发组件
-举个例子
## 3 如何开发组件
以lottie动画组件为例,
本章节提到全部示例源码可以在Hello UTS 中找到
>
本章节提到全部示例源码可以在Hello UTS 中找到
#### 3.1 创建组件
UTS组件的创建过程与UTS插件一样。
选中 项目目录/uni_modules 右键 新建组件
选中 项目目录/uni_modules 右键 新建组件
TODO
#### 3.2 目录结构
![
目录结构
](
https://native-res.dcloud.net.cn/images/uts/component/image1.png
)
![
目录结构
](
https://native-res.dcloud.net.cn/images/uts/component/image1.png
)
组件的入口文件是index.vue,具体规范会在下一个章节介绍
另外 组件允许存在入口文件:index.uts 对外提供函数能力,具体参考 UTS 插件介绍
入口文件是index.vue
#### 3.2 示例代码简介
下面是一个组件源码 index.vue 完整示例:
```
uts
//原生提供以下属性或方法的实现
export default {
/**
* 组件名称,也就是开发者使用的标签
*/
name: "xxx-view",
/**
* 组件涉及的事件声明
* 组件涉及的事件声明
,只有声明过的事件,才能被正常发送
*/
emits: ['bindended'],
/**
* 属性声明,组件的使用者会传递这些属性值到组件
*/
props: {
/**
*
属性A:propA 需要声明属性类型和默认值
*
字符串类型 属性:path 默认值:""
*/
"p
ropA
": {
"p
ath
": {
type: String,
default: ""
},
},
/**
* 组件内部变量声明
*/
data() {
return {
}
},
/**
* 属性变化监听器实现
*/
watch: {
"propA": {
handler(newPropA: string) {
// 这里处理属性newPropA 的更新逻辑
"path": {
handler(newPath: string) {
// 这里处理属性newPath 的更新逻辑
},
immediate: false //创建时是否通过此方法更新属性,默认值为false
//创建时是否通过此方法更新属性,默认值为false
immediate: false
},
},
// 规则:如果没有配置expose,则methods中的方法均对外暴露,如果配置了expose,则以expose的配置为准向外暴露
// 只有 `publicMethod` 在实例上可用
/**
* 规则:如果没有配置expose,则methods中的方法均对外暴露,如果配置了expose,则以expose的配置为准向外暴露
* ['publicMethod'] 含义为:只有 `publicMethod` 在实例上可用
*/
expose: ['publicMethod'],
methods: {
/**
* 对外公开的组件方法
*/
publicMethod() {
doSth(paramA: string) {
// 这是组件的自定义方法
}
},
/**
* 内部使用的组件方法
*/
privateMethod() {
doSth(paramA: string) {
doSth
Inner
(paramA: string) {
// 这是组件的自定义方法
}
}
},
created() { //创建组件,替换created
/**
* 组件被创建,组件第一个生命周期,
* 在内存中被占用的时候被调用,开发者可以在这里执行一些需要提前执行的初始化逻辑
* [可选实现]
*/
created() {
},
NVBeforeLoad() { //组件将要创建,对应前端beforeMount
//可选实现,这里可以提前做一些操作
/**
* 对应平台的view载体即将被创建,对应前端beforeMount
* [可选实现]
*/
NVBeforeLoad() {
},
NVLoad(): View { //创建原生View,必须定义返回值类型(Android需要明确知道View类型,需特殊校验)
//必须实现
/**
* 创建原生View,必须定义返回值类型
* 开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型
* (Android需要明确知道View类型,需特殊校验)
* todo 补充IOS平台限制
* [必须实现]
*/
NVLoad(): View {
let viewInstance = new View($androidContext)
return aView
},
/**
* 原生View已创建
* [可选实现]
*/
NVLoaded() {
NVLoaded() { //原生View已创建
//可选实现,这里可以做后续操作
},
NVLayouted() { //原生View布局完成
//可选实现,这里可以做布局后续操作
/**
* 原生View布局完成
* [可选实现]
*/
NVLayouted() {
},
NVBeforeUnload() { //原生View将释放
//可选实现,这里可以做释放View之前的操作
/**
* 原生View将释放
* [可选实现]
*/
NVBeforeUnload() {
},
NVUnloaded() { //原生View已释放
//可选实现,这里可以做释放View之后的操作
/**
* 原生View已释放,这里可以做释放View之后的操作
* [可选实现]
*/
NVUnloaded() {
},
unmounted() { //组件销毁
//可选实现
/**
* 组件销毁
* [可选实现]
*/
unmounted() {
}
/**
* 自定组件布局尺寸
* [可选实现]
*/
doMeasure(size: UTSSize): UTSSize {
size.width = 120.0.toFloat()
size.height = 800.0.toFloat()
return size
}
}
```
#### 3.3 组件开发关键函数
index.vue可以分为以下几类:
+
配置:
首先开发者需要重点关注的是 NVLoad 函数,开发者需要在这个函数内实现View载体的具体实现
name:组件的使用标签,可以省略,若省略则默认为组件名称
```
let viewInstance = new View($androidContext)
return aView
```
emits:组件允许的消息事件名称,如果没有组件消息,不需要配置
除了组件的基本功能外,组件还以属性和方法的形式为使用者提供额外的功能
+
属性:
组件的开发者,声明属性
```
props: {
/**
* 属性A:propA 需要声明属性类型和默认值
*/
"propA": {
type: String,
default: ""
},
},
```
props:需要由组件的使用者提供,比如一个Image组件,会需要一个path属性作为图像路径来源
组件使用者,使用属性
```
js
<
xxx
-
view
:
propA
=
"
自定义属性值
"
>
<
/xxx-view>
```
watch:属性的监听实现,用来监听属性数据更新。
组件的开发者,定义公开方法
+
数据:
```
methods: {
publicMethod() {
doSth(paramA: string) {
// 这是组件的自定义方法
}
}
}
```
组件使用者,使用方法
data:组件内部数据定义,用于组件内部逻辑处理,不对外暴露
```
js
// 布局代码
<
xxx
-
view
ref
=
"
xxxView
"
>
<
/xxx-view
>
// 调用代码
this
.
$refs
[
"
xxxView
"
].
doSth
(
'
字符串参数
'
)
```
+
方法:
#### 3.4 使用组件
methods:组件方法定义,可以通过与expose组合使用,区分对内方法和对外方法
1 需要自定义基座方能使用
2 不需要特殊引用,直接使用自定义
```
js
<
xxx
-
view
:
propA
=
"
自定义属性值
"
ref
=
"
当前组件标签
"
>
<
/xxx-view>
```
expose:与methods 字段配合使用,用以区分组件对内方法和对外方法
+
生命周期:
组件需要重点处理 内存创建/销毁,View载体创建/销毁 过程中的资源管理,具体参考3.4章节
3 调用组件的方法
+
内置对象:
为了方便组件开发者,UTS组件内置了部分变量与函数,具体参考3.5章节
参考Hello UTS ,源码路径:
~
\p
ages
\S
DKIntegration
\L
ottie
\i
ndex.nvue
#### 3.4 生命周期
## 4 组件的生命周期
组件开发者需要重点关注生命周期
![
生命周期
](
https://native-res.dcloud.net.cn/images/uts/component/image2.png
)
...
...
@@ -229,7 +257,12 @@ methods: {
+
NVLoad:
组件对应平台的view载体 正在被创建,开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型
[必须实现]
组件 view载体的创建实现
开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型
+
NVLayouted:
...
...
@@ -253,4 +286,104 @@ view载体被回收
资源回收
+
doMeasure:
doMeasure 用于告诉排版系统,组件自身需要的宽高,具体的调用时机由排版系统决定。
一般情况下,组件的宽高应该是由终端系统的排版引擎决定,组件开发者不需要实现此函数。
但是部分场景下,组件开发者需要自己维护宽高,则需要开发者重写此函数
#### 3.5 内置对象和函数
为了方便组件开发者使用,UTS 组件内部内置了下列对象:
|变量名 |类型 |简介 |平台限制 |
|:------- |:-------- |:-------- |:--- |
|$el |对象 |当前View实例对象 |全部平台 |
|$androidContext|对象 |当前组件上下文 |仅android |
|emit("event") |函数 |发送已注册的事件 |全部平台 |
## 4 使用组件
#### 4.1 注意事项:
1.
需要自定义基座方能使用
2 不需要引用,直接使用自定义标签
```
js
<
xxx
-
view
:
propA
=
"
自定义属性值
"
ref
=
"
当前组件标签
"
>
<
/xxx-view>
```
#### 4.2 属性
组件的开发者,声明属性
```
props: {
/**
* 属性A:propA 需要声明属性类型和默认值
*/
"propA": {
type: String,
default: ""
},
},
```
组件使用者,使用属性
```
js
<
xxx
-
view
:
propA
=
"
自定义属性值
"
>
<
/xxx-view>
```
#### 4.3 方法
组件的开发者,定义公开方法
```
methods: {
publicMethod() {
doSth(paramA: string) {
// 这是组件的自定义方法
}
}
}
```
组件使用者,使用方法
```
js
// 布局代码
<
xxx
-
view
ref
=
"
customTag
"
>
<
/xxx-view
>
// 调用代码
this
.
$refs
[
"
customTag
"
].
doSth
(
'
参数
'
)
```
## 5 快速体验
开发者可以使用
[
Hello UTS
](
https://gitcode.net/dcloud/hello-uts
)
快速体验UTS 组件开发
使用HX 3.6.16 版本 - 选择 Hello UTS - 自定义基座包。
查看:三方SDK-Lottie动画示例,对应的源码实现:~/uni_modules/uts-animation-view
## 常见问题
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录