Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-zh
提交
78df53a8
unidocs-zh
项目概览
DCloud
/
unidocs-zh
通知
3216
Star
106
Fork
815
代码
文件
提交
分支
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看板
提交
78df53a8
编写于
1月 09, 2023
作者:
杜庆泉
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
uts组件文档修改进行中
上级
ac2925b8
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
268 addition
and
121 deletion
+268
-121
docs/plugin/uts-component.md
docs/plugin/uts-component.md
+268
-121
未找到文件。
docs/plugin/uts-component.md
浏览文件 @
78df53a8
...
@@ -44,27 +44,12 @@ UTS组件的优势在于,它秉承了UTS的跨平台特性,统一的UTS语
...
@@ -44,27 +44,12 @@ UTS组件的优势在于,它秉承了UTS的跨平台特性,统一的UTS语
为了降低前端开发者的开发门槛,UTS组件采用了类Vue组件的语法,
[
关于Vue组件
](
https://cn.vuejs.org/guide/essentials/component-basics.html
)
,但是具体的函数上会有定制,我们会在下一个章节详细介绍
为了降低前端开发者的开发门槛,UTS组件采用了类Vue组件的语法,
[
关于Vue组件
](
https://cn.vuejs.org/guide/essentials/component-basics.html
)
,但是具体的函数上会有定制,我们会在下一个章节详细介绍
## 如何开发UTS组件
## UTS组件结构解析
#### 创建UTS组件
HBuilderX 3.6.16 版本之后,支持一键创建
选中 项目目录/uni_modules 右键 新建组件
TODO
至此,我们已经得到了一个最基本的UTS插件目录,下个章节我们介绍其中各文件的作用
#### UTS组件目录结构
#### UTS组件目录结构
![
目录结构
](
https://native-res.dcloud.net.cn/images/uts/component/image1.png
)
<pre
v-pre=
""
data-lang=
""
>
<pre
v-pre=
""
data-lang=
""
>
<code
class=
"lang-"
style=
"padding:0"
>
<code
class=
"lang-"
style=
"padding:0"
>
┌─common // 可跨端公用的uts代码。推荐,不强制
┌─common // 可跨端公用的uts代码。推荐,不强制
...
@@ -104,152 +89,176 @@ TODO
...
@@ -104,152 +89,176 @@ TODO
</pre>
</pre>
如上所示,UTS组件的目录结构与UTS插件基本相同
。
如上所示,UTS组件的目录结构与UTS插件基本相同
唯一的差别在于,UTS组件入口文件有两个,一个必选的index.vue 组件入口,和一个可选的index.uts 函数能力入口
唯一的差别在于,UTS组件入口文件有两个,一个必选的index.vue 组件入口,和一个可选的index.uts 函数能力入口
用户如果在开发组件的同时,存在一些与组件无关的能力需要对外暴露,可以在index.uts中进行实现
用户如果在开发组件的同时,存在一些与组件无关的能力需要对外暴露,则可以同时开发两个入口。
大多数情况下,我们只需要开发一个index.vue 即可,如果存在多个组件,可以新建多个
*
.vue文件
大多数情况下,组件其实我们只需要开发一个index.vue 即可,关于index.vue 的具体规范会在下一个章节介绍
关于index.vue 的源码规范会在下一个章节介绍
#### UTS组件
代码格式
解析
#### UTS组件
源码
解析
下面是一个组件源码 index.vue 完整示例:
下面是一个组件源码 index.vue 完整示例:
```
ts
```
ts
export
default
{
<
template
>
<
view
class
=
"
defaultStyles
"
>
<
/view
>
<
/template
>
<
script
lang
=
"
uts
"
>
import
TextUtils
from
'
android.text.TextUtils
'
import
Button
from
'
android.widget.Button
'
import
LinearLayout
from
'
android.widget.LinearLayout
'
import
Color
from
'
android.graphics.Color
'
import
View
from
'
android.view.View
'
class
ButtonClickListsner
extends
View
.
OnClickListener
{
constructor
()
{}
override
onClick
(
v
?
:
View
)
{
console
.
log
(
v
)
}
}
//原生提供以下属性或方法的实现
export
default
{
/**
/**
* 组件名称,也就是开发者使用的标签
* 组件名称,也就是开发者使用的标签
*/
*/
name
:
"
xxx
-view
"
,
name
:
"
uts-hello
-view
"
,
/**
/**
* 组件涉及的事件声明,只有声明过的事件,才能被正常发送
* 组件涉及的事件声明,只有声明过的事件,才能被正常发送
*/
*/
emits
:
[
'
bindended
'
],
emits
:
[
'
buttonClick
'
],
/**
/**
* 属性声明,组件的使用者会传递这些属性值到组件
* 属性声明,组件的使用者会传递这些属性值到组件
*/
*/
props
:
{
props
:
{
/**
/**
* 字符串类型 属性:path 默认值:""
* 字符串类型 属性:buttonText 需要设置默认值
*/
*/
"
path
"
:
{
"
buttonText
"
:
{
type
:
String
,
type
:
String
,
default
:
"
"
default
:
"
点击触发
"
},
}
},
},
/**
/**
* 组件内部变量声明
* 组件内部变量声明
*/
*/
data
()
{
data
()
{
return
{
return
{}
}
},
},
/**
/**
* 属性变化监听器实现
* 属性变化监听器实现
*/
*/
watch
:
{
watch
:
{
"
buttonText
"
:
{
"
path
"
:
{
/**
handler
(
newPath
:
string
)
{
* 这里监听属性变化,并进行组件内部更新
// 这里处理属性newPath 的更新逻辑
*/
},
handler
(
newButtonText
:
string
)
{
//创建时是否通过此方法更新属性,默认值为false
if
(
this
.
$el
!=
null
)
{
immediate
:
false
let
button
=
this
.
$el
!
.
findViewWithTag
(
"
centerButton
"
)
as
Button
},
if
(
!
TextUtils
.
isEmpty
(
newButtonText
))
{
},
button
.
setText
(
newButtonText
)
}
}
},
immediate
:
false
//创建时是否通过此方法更新属性,默认值为false
},
},
/**
/**
* 规则:如果没有配置expose,则methods中的方法均对外暴露,如果配置了expose,则以expose的配置为准向外暴露
* 规则:如果没有配置expose,则methods中的方法均对外暴露,如果配置了expose,则以expose的配置为准向外暴露
* ['publicMethod'] 含义为:只有 `publicMethod` 在实例上可用
* ['publicMethod'] 含义为:只有 `publicMethod` 在实例上可用
*/
*/
expose
:
[
'
publicMethod
'
],
expose
:
[
'
doSth
'
],
methods
:
{
methods
:
{
/**
/**
* 对外公开的组件方法
* 对外公开的组件方法
*/
*/
publicMethod
()
{
doSth
(
paramA
:
string
)
{
doSth
(
paramA
:
string
)
{
// 这是组件的自定义方法
// 这是组件的自定义方法
console
.
log
(
"
paramA
"
)
}
},
},
/**
/**
* 内部使用的组件方法
* 内部使用的组件方法
*/
*/
privateMethod
()
{
privateMethod
()
{
doSthInner
(
paramA
:
string
)
{
// 这是组件的自定义方法
}
}
}
},
},
/**
/**
* 组件被创建,组件第一个生命周期,
* 组件被创建,组件第一个生命周期,
* 在内存中被占用的时候被调用,开发者可以在这里执行一些需要提前执行的初始化逻辑
* 在内存中被占用的时候被调用,开发者可以在这里执行一些需要提前执行的初始化逻辑
* [可选实现]
* [可选实现]
*/
*/
created
()
{
created
()
{
},
},
/**
/**
* 对应平台的view载体即将被创建,对应前端beforeMount
* 对应平台的view载体即将被创建,对应前端beforeMount
* [可选实现]
* [可选实现]
*/
*/
NVBeforeLoad
()
{
NVBeforeLoad
()
{
},
},
/**
/**
* 创建原生View,必须定义返回值类型
* 创建原生View,必须定义返回值类型
* 开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型
* 开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型
* (Android需要明确知道View类型,需特殊校验)
* (Android需要明确知道View类型,需特殊校验)
* todo 补充IOS平台限制
* todo 补充IOS平台限制
* [必须实现]
* [必须实现]
*/
*/
NVLoad
():
View
{
NVLoad
():
LinearLayout
{
let
viewInstance
=
new
View
(
$androidContext
)
//必须实现
return
aView
let
contentLayout
=
new
LinearLayout
(
$androidContext
)
},
let
button
=
new
Button
(
$androidContext
)
button
.
setText
(
"
点击触发
"
);
button
.
setTag
(
"
centerButton
"
);
contentLayout
.
addView
(
button
,
LinearLayout
.
LayoutParams
(
500
,
500
));
button
.
setOnClickListener
(
new
ButtonClickListsner
())
return
contentLayout
},
/**
/**
* 原生View已创建
* 原生View已创建
* [可选实现]
* [可选实现]
*/
*/
NVLoaded
()
{
NVLoaded
()
{
},
},
/**
/**
* 原生View布局完成
* 原生View布局完成
* [可选实现]
* [可选实现]
*/
*/
NVLayouted
()
{
NVLayouted
()
{
},
},
/**
/**
* 原生View将释放
* 原生View将释放
* [可选实现]
* [可选实现]
*/
*/
NVBeforeUnload
()
{
NVBeforeUnload
()
{},
},
/**
/**
* 原生View已释放,这里可以做释放View之后的操作
* 原生View已释放,这里可以做释放View之后的操作
* [可选实现]
* [可选实现]
*/
*/
NVUnloaded
()
{
NVUnloaded
()
{
},
},
/**
/**
* 组件销毁
* 组件销毁
* [可选实现]
* [可选实现]
*/
*/
unmounted
()
{
unmounted
()
{}
}
/**
/**
* 自定组件布局尺寸
* 自定组件布局尺寸
* [可选实现]
* [可选实现]
...
@@ -259,10 +268,20 @@ TODO
...
@@ -259,10 +268,20 @@ TODO
size
.
height
=
800.0
.
toFloat
()
size
.
height
=
800.0
.
toFloat
()
return
size
return
size
}
}
}
}
<
/script
>
<
style
>
/* 定义默认样式值, 组件使用者没有配置时使用 */
.
defaultStyles
{
width
:
750
rpx
;
height
:
240
rpx
;
background
-
color
:
blue
;
}
<
/style
>
```
```
index.vue可以分为以下几类:
index.vue可以分为以下几类:
+
配置:
+
配置:
...
@@ -301,77 +320,205 @@ index.vue可以分为以下几类:
...
@@ -301,77 +320,205 @@ index.vue可以分为以下几类:
组件开发者需要重点关注生命周期
组件开发者需要重点关注生命周期
```
mermaid
graph TD;
Create-->NVBeforeLoad;
subgraph View生命周期
NVBeforeLoad-->NVLoad;
NVLoad-->NVLoaded;
NVLoaded-->NVLayouted;
NVLayouted-->NVBeforeUnload;
end
NVBeforeUnload-->unmounted;
```
![
生命周期
](
https://native-res.dcloud.net.cn/images/uts/component/image2.png
)
|函数名 |描述 |建议行为 |是否可选 |
|:---- |:--- |:--- |:--- |
|created |组件在内存中被创建 |开发者可以在这里执行一些需要最早执行的初始化逻辑|可选|
|NVBeforeLoad |组件对应平台的view载体,即将被创建|开发者可以在这里执行一些需要在View创建前初始化的逻辑|可选|
|NVLoad |组件view载体正在被创建实现|开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型|必须实现|
|NVLayouted |组件对应平台的view载体已布局结束 |需要在view布局结束后执行的逻辑 |可选|
|NVBeforeUnload |view载体即将被卸载 |View卸载前,需要回收资源的逻辑 |可选|
|NVUnloaded |view载体已经被卸载 |View卸载后,需要回收资源的逻辑 |可选|
|unmounted |组件在内存被销毁 |资源回收逻辑 |可选|
+
created:
组件被创建,组件第一个生命周期,在内存中被占用的时候被调用,开发者可以在这里执行一些需要提前执行的初始化逻辑
除上述生命周期外,还存在下列可选周期函数:
+
NVBeforeLoad
:
+
doMeasure
:
组件对应平台的view载体 即将被创建
doMeasure 用于告诉排版系统,组件自身需要的宽高,具体的调用时机由排版系统决定。
+
NVLoad:
一般情况下,组件的宽高应该是由终端系统的排版引擎决定,组件开发者不需要实现此函数。
[必须实现]
但是部分场景下,组件开发者需要自己维护宽高,则需要开发者重写此函数
组件 view载体的创建实现
开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型
#### 内置对象和函数
+
NVLayouted
:
为了方便组件开发者使用,UTS 组件内部内置了下列对象
:
组件对应平台的view载体,布局完成
|变量名 |类型 |简介 |平台限制 |方法&属性 |
|:------- |:-------- |:-------- |:--- |:--- |
|$el |对象 |当前View实例对象 |全部平台 |开发者在NVLoad返回的对象类型|
|$androidContext|对象 |当前组件上下文 |仅android |android平台对应Context对象|
|emit("event") |函数 |发送已注册的事件 |全部平台 ||
+
NVBeforeUnload:
view载体即将被卸载
资源回收
+
NVUnloaded:
## 简单View的示例
view载体已经被卸载
#### 创建插件
资源回收
在HBuilder X 中选中Uni-App项目下 uni_modules目录
+
unmounted:
todo 目前还没有创建界面
view载体被回收
资源回收
这是创建后的目录结构
+
doMeasure:
![
目录结构
](
https://native-res.dcloud.net.cn/images/uts/component/image1.png
)
doMeasure 用于告诉排版系统,组件自身需要的宽高,具体的调用时机由排版系统决定。
一般情况下,组件的宽高应该是由终端系统的排版引擎决定,组件开发者不需要实现此函数。
#### 编写逻辑
但是部分场景下,组件开发者需要自己维护宽高,则需要开发者重写此函数
打开index.vue,键入下面的组件源码:
```
ts
<
template
>
<
view
class
=
"
defaultStyles
"
>
<
/view
>
<
/template
>
<
script
lang
=
"
uts
"
>
import
TextUtils
from
'
android.text.TextUtils
'
import
Button
from
'
android.widget.Button
'
import
LinearLayout
from
'
android.widget.LinearLayout
'
import
Color
from
'
android.graphics.Color
'
import
View
from
'
android.view.View
'
class
ButtonClickListsner
extends
View
.
OnClickListener
{
constructor
()
{}
override
onClick
(
v
?
:
View
)
{
console
.
log
(
v
)
}
}
//原生提供以下属性或方法的实现
export
default
{
/**
* 组件名称,也就是开发者使用的标签
*/
name
:
"
uts-hello-view
"
,
/**
* 组件涉及的事件声明,只有声明过的事件,才能被正常发送
*/
emits
:
[
'
buttonClick
'
],
/**
* 属性声明,组件的使用者会传递这些属性值到组件
*/
props
:
{
/**
* 字符串类型 属性:buttonText 需要设置默认值
*/
"
buttonText
"
:
{
type
:
String
,
default
:
"
点击触发
"
}
},
/**
* 属性变化监听器实现
*/
watch
:
{
"
buttonText
"
:
{
/**
* 这里监听属性变化,并进行组件内部更新
*/
handler
(
newButtonText
:
string
)
{
if
(
this
.
$el
!=
null
)
{
let
button
=
this
.
$el
!
.
findViewWithTag
(
"
centerButton
"
)
as
Button
if
(
!
TextUtils
.
isEmpty
(
newButtonText
))
{
button
.
setText
(
newButtonText
)
}
}
}
},
},
NVLoad
():
LinearLayout
{
//必须实现
let
contentLayout
=
new
LinearLayout
(
$androidContext
)
let
button
=
new
Button
(
$androidContext
)
button
.
setText
(
"
点击触发
"
);
button
.
setTag
(
"
centerButton
"
);
contentLayout
.
addView
(
button
,
LinearLayout
.
LayoutParams
(
500
,
500
));
button
.
setOnClickListener
(
new
ButtonClickListsner
())
return
contentLayout
},
}
<
/script
>
<
style
>
/* 定义默认样式值, 组件使用者没有配置时使用 */
.
defaultStyles
{
width
:
750
rpx
;
height
:
240
rpx
;
background
-
color
:
blue
;
}
<
/style
>
```
#### 使用组件
#### 内置对象和函数
打开任意 componet.nvue文件
```
js
<
uts
-
hello
-
view
buttonText
=
"
点击按钮内容
"
style
=
"
width:375px;height: 375px;background-color: aqua;
"
><
/uts-hello-view>
```
为了方便组件开发者使用,UTS 组件内部内置了下列对象:
|变量名 |类型 |简介 |平台限制 |
## 包含第三方SDK的示例
|:------- |:-------- |:-------- |:--- |
|$el |对象 |当前View实例对象 |全部平台 |
|$androidContext|对象 |当前组件上下文 |仅android |
|emit("event") |函数 |发送已注册的事件 |全部平台 |
#### 创建插件
在HBuilder X 中选中Uni-App项目下 uni_modules目录
todo 目前还没有创建界面
这是创建后的目录结构
![
目录结构
](
https://native-res.dcloud.net.cn/images/uts/component/image1.png
)
#### 引入依赖
打开 ~/uni_modules/uts-animation-view/utssdk/app-android/config.json
键入如下代码:
```
"dependencies": [
"com.airbnb.android:lottie:3.4.0"
]
```
UTS组件建议使用远程依赖的方式集成,如果需要以AAR的形式添加SDK,可以添加到
## UTS组件开发使用示例
~/uni_modules/uts-animation-view/utssdk/app-android/libs目录
#### 编写逻辑
## 包含第三方功能的 UTS组件开发使用示例
#### 使用组件
#### 使用组件的注意事项
#### 使用组件的注意事项
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录