Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-zh
提交
3cc297c6
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看板
提交
3cc297c6
编写于
8月 28, 2023
作者:
DCloud-WZF
💬
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
docs(vue3): component uni-app x compatibility
上级
681859cf
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
138 addition
and
10 deletion
+138
-10
docs/tutorial/vue3-components.md
docs/tutorial/vue3-components.md
+138
-10
未找到文件。
docs/tutorial/vue3-components.md
浏览文件 @
3cc297c6
...
@@ -210,7 +210,7 @@
...
@@ -210,7 +210,7 @@
##### 示例:
##### 示例:
> uni-app js 引擎版
```
html
```
html
<template>
<template>
<view>
<view>
...
@@ -234,6 +234,30 @@
...
@@ -234,6 +234,30 @@
}
}
</script>
</script>
```
```
> uni-app x
```
html
<template>
<view>
<!-- 我是子组件componentA -->
<view>
{{age}}
</view>
</view>
</template>
<script>
export
default
{
props
:
{
// 检测类型 + 其他验证
age
:
{
type
:
Number
,
default
:
0
,
required
:
true
,
validator
:
function
(
value
):
boolean
{
return
value
>=
0
}
}
}
}
</script>
```
```
html
```
html
<template>
<template>
...
@@ -361,7 +385,7 @@
...
@@ -361,7 +385,7 @@
1.
**这个 `prop` 用来传递一个初始值**
;这个子组件接下来希望将其作为一个本地的
`prop`
数据来使用。在这种情况下,最好定义一个本地的
`data property `
并将这个
`prop`
作为其初始值:
1.
**这个 `prop` 用来传递一个初始值**
;这个子组件接下来希望将其作为一个本地的
`prop`
数据来使用。在这种情况下,最好定义一个本地的
`data property `
并将这个
`prop`
作为其初始值:
> uni-app js 引擎版
```
html
```
html
<template>
<template>
<view>
<view>
...
@@ -380,6 +404,29 @@
...
@@ -380,6 +404,29 @@
}
}
</script>
</script>
```
```
> uni-app x
```
html
<template>
<view>
<!-- 我是子组件componentA -->
<view>
{{myTitle}}
</view>
</view>
</template>
<script>
export
default
{
props
:
{
title
:
{
type
:
String
}
},
data
()
{
return
{
myTitle
:
this
.
title
as
string
}
}
}
</script>
```
```
html
```
html
<template>
<template>
...
@@ -403,7 +450,7 @@
...
@@ -403,7 +450,7 @@
2.
**这个 `prop` 以一种原始的值传入且需要进行转换**
。在这种情况下,最好使用这个
`prop`
的值来定义一个计算属性:
2.
**这个 `prop` 以一种原始的值传入且需要进行转换**
。在这种情况下,最好使用这个
`prop`
的值来定义一个计算属性:
> uni-app js 引擎版
```
html
```
html
<template>
<template>
<view>
<view>
...
@@ -422,6 +469,29 @@
...
@@ -422,6 +469,29 @@
}
}
</script>
</script>
```
```
> uni-app x
```
html
<template>
<view>
<!-- 我是子组件componentA -->
<view>
{{normalizedSize}}
</view>
</view>
</template>
<script>
export
default
{
props
:
{
size
:
{
type
:
String
}
},
computed
:
{
normalizedSize
:
function
():
string
{
return
this
.
size
.
toLowerCase
()
}
}
}
</script>
```
```
html
```
html
<template>
<template>
...
@@ -454,7 +524,7 @@
...
@@ -454,7 +524,7 @@
为了定制
`prop`
的验证方式,你可以为
`props`
中的值提供一个带有验证需求的对象,而不是一个字符串数组。例如:
为了定制
`prop`
的验证方式,你可以为
`props`
中的值提供一个带有验证需求的对象,而不是一个字符串数组。例如:
> uni-app js 引擎版
```
js
```
js
props
:
{
props
:
{
// 基础的类型检查 (`null` 和 `undefined` 会通过任何类型验证)
// 基础的类型检查 (`null` 和 `undefined` 会通过任何类型验证)
...
@@ -496,6 +566,47 @@
...
@@ -496,6 +566,47 @@
}
}
}
}
```
```
> uni-app x
```
js
props
:
{
propA
:
{
type
:
Number
},
// 必填的字符串
propC
:
{
type
:
String
,
required
:
true
},
// 带有默认值的数字
propD
:
{
type
:
Number
,
default
:
100
},
// 带有默认值的对象
propE
:
{
type
:
UTSObject
,
// 对象或数组默认值必须从一个工厂函数获取
default
:
function
():
UTSObject
{
return
{
message
:
'
hello
'
}
}
},
// 自定义验证函数
propF
:
{
validator
:
function
(
value
):
boolean
{
// 这个值必须匹配下列字符串中的一个
return
[
'
success
'
,
'
warning
'
,
'
danger
'
].
indexOf
(
value
)
!==
-
1
}
},
// 具有默认值的函数
propG
:
{
type
:
Function
,
// 与对象或数组默认值不同,这不是一个工厂函数 —— 这是一个用作默认值的函数
default
:
function
():
string
{
return
'
Default function
'
}
}
}
```
当
`prop`
验证失败的时候,(开发环境构建版本的)
`Vue`
将会产生一个控制台的警告。
当
`prop`
验证失败的时候,(开发环境构建版本的)
`Vue`
将会产生一个控制台的警告。
...
@@ -537,12 +648,14 @@
...
@@ -537,12 +648,14 @@
用于验证
`author`
prop 的值是否是通过
`new Person`
创建的。
用于验证
`author`
prop 的值是否是通过
`new Person`
创建的。
**注意:uni-app x 暂不支持**
### Prop 的大小写命名
### Prop 的大小写命名
`HTML`
中的
`attribute`
名是大小写不敏感的,所以浏览器会把所有大写字符解释为小写字符。这意味着当你使用
`DOM`
中的模板时,
`camelCase`
(驼峰命名法) 的
`prop`
名需要使用其等价的
`kebab-case`
(短横线分隔命名) 命名:
`HTML`
中的
`attribute`
名是大小写不敏感的,所以浏览器会把所有大写字符解释为小写字符。这意味着当你使用
`DOM`
中的模板时,
`camelCase`
(驼峰命名法) 的
`prop`
名需要使用其等价的
`kebab-case`
(短横线分隔命名) 命名:
> uni-app js 引擎版
```
html
```
html
<template>
<template>
<view>
<view>
...
@@ -557,6 +670,25 @@
...
@@ -557,6 +670,25 @@
}
}
</script>
</script>
```
```
> uni-app x
```
html
<template>
<view>
<!-- 我是子组件componentA -->
<view>
{{postTitle}}
</view>
</view>
</template>
<script>
export
default
{
props
:
{
postTitle
:
{
type
:
String
}
}
}
</script>
```
```
html
```
html
<template>
<template>
...
@@ -844,9 +976,7 @@
...
@@ -844,9 +976,7 @@
}
}
```
```
**注意:uni-app x 暂不支持**
### v-model 参数
### v-model 参数
...
@@ -1001,7 +1131,7 @@
...
@@ -1001,7 +1131,7 @@
</script>
</script>
```
```
**注意:uni-app x 暂不支持 capitalize 修饰符**
```
html
```
html
<!-- 我是 my-component子组件-->
<!-- 我是 my-component子组件-->
...
@@ -1038,10 +1168,8 @@
...
@@ -1038,10 +1168,8 @@
</script>
</script>
```
```
对于带参数的
`v-model`
绑定,生成的
`prop`
名称将为
`arg + "Modifiers"`
:
对于带参数的
`v-model`
绑定,生成的
`prop`
名称将为
`arg + "Modifiers"`
:
```
html
```
html
<my-component
v-model:foo.capitalize=
"bar"
></my-component>
<my-component
v-model:foo.capitalize=
"bar"
></my-component>
```
```
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录