Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-zh
提交
50844e5b
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看板
提交
50844e5b
编写于
12月 13, 2023
作者:
杜庆泉
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Update uts-component.md
上级
1e3d5096
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
98 addition
and
15 deletion
+98
-15
docs/plugin/uts-component.md
docs/plugin/uts-component.md
+98
-15
未找到文件。
docs/plugin/uts-component.md
浏览文件 @
50844e5b
...
...
@@ -599,41 +599,63 @@ NVUpdateStyles(styles: Map<String, any>){
> Android
```
html
<template>
<view>
<view
>
</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
()
{
super
()
}
override
onClick
(
v
?
:
View
)
{
console
.
log
(
v
)
}
}
//原生提供以下属性或方法的实现
//原生提供以下属性或方法的实现
export
default
{
/**
* 组件名称,也就是开发者使用的标签
*/
name
:
"
uts-hello-view
"
,
/**
* 组件涉及的事件声明,只有声明过的事件,才能被正常发送
*/
emits
:
[
'
buttonClick
'
],
/**
* 属性声明,组件的使用者会传递这些属性值到组件
*/
props
:
{
/**
* 字符串类型 属性:buttonText 需要设置默认值
*/
"
buttonText
"
:
{
type
:
String
,
default
:
"
点击触发
"
}
},
/**
* 组件内部变量声明
*/
data
()
{
return
{}
},
/**
* 属性变化监听器实现
*/
watch
:
{
"
buttonText
"
:
{
/**
* 这里监听属性变化,并进行组件内部更新
*/
handler
(
newButtonText
:
string
)
{
if
(
this
.
$el
!=
null
)
{
let
button
=
this
.
$el
!
.
findViewWithTag
(
"
centerButton
"
)
as
Button
...
...
@@ -641,25 +663,69 @@ NVUpdateStyles(styles: Map<String, any>){
button
.
setText
(
newButtonText
)
}
}
}
},
immediate
:
false
//创建时是否通过此方法更新属性,默认值为false
},
},
/**
* 规则:如果没有配置expose,则methods中的方法均对外暴露,如果配置了expose,则以expose的配置为准向外暴露
* ['publicMethod'] 含义为:只有 `publicMethod` 在实例上可用
*/
expose
:
[
'
doSth
'
],
methods
:
{
/**
* 对外公开的组件方法
*/
doSth
(
paramA
:
string
)
{
// 这是组件的自定义方法
console
.
log
(
"
paramA
"
,
paramA
)
},
/**
* 内部使用的组件方法
*/
privateMethod
()
{
}
},
/**
* 组件被创建,组件第一个生命周期,
* 在内存中被占用的时候被调用,开发者可以在这里执行一些需要提前执行的初始化逻辑
* [可选实现]
*/
created
()
{
},
/**
* 对应平台的view载体即将被创建,对应前端beforeMount
* [可选实现]
*/
NVBeforeLoad
()
{
},
/**
* 创建原生View,必须定义返回值类型
* 开发者需要重点实现这个函数,声明原生组件被创建出来的过程,以及最终生成的原生组件类型
* (Android需要明确知道View类型,需特殊校验)
* todo 补充IOS平台限制
* [必须实现]
*/
NVLoad
():
LinearLayout
{
//必须实现
//必须实现
let
contentLayout
=
new
LinearLayout
(
this
.
$androidContext
)
let
button
=
new
Button
(
this
.
$androidContext
)
button
.
setText
(
"
点击触发
"
);
button
.
setTag
(
"
centerButton
"
);
contentLayout
.
addView
(
button
,
new
LinearLayout
.
LayoutParams
(
500
,
500
));
button
.
setOnClickListener
(
new
ButtonClickListsner
())
return
contentLayout
},
}
}
</script>
<style>
</style>
```
...
...
@@ -752,17 +818,34 @@ NVUpdateStyles(styles: Map<String, any>){
直接使用
`uts-hello-view`
标签,并且定义
`buttonText`
文本内容即可看到效果。
点击按钮,可以在控制台看到组件内部实现的日志输出
点击组件内置按钮,可以在控制台看到组件内部实现的日志输出
点击
`调用组件的方法`
按钮,可以看到组件内置方法被调用
```
html
<template>
<div>
<
text>
UTS view组件
</text
>
<uts-hello-view
buttonText=
"点击按钮内容"
style=
"width:375px;height: 375px;background-color: aqua;"
></uts-hello-view
>
<
uts-hello-view
ref=
"helloView"
buttonText=
"点击按钮内容"
style=
"width:375px;height: 375px;background-color: aqua;"
></uts-hello-view
>
<button
@
tap=
"callComponentMethod"
>
调用组件的方法
</button
>
</div>
</template>
<script>
export
default
{
data
()
{
return
{
}
},
methods
:
{
// 调用组件内的方法
callComponentMethod
:
function
()
{
this
.
$refs
[
"
helloView
"
].
doSth
(
"
param doSth
"
);
},
}
}
</script>
<style>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录