Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-uni-app-x-zh
提交
0f23b28e
U
unidocs-uni-app-x-zh
项目概览
DCloud
/
unidocs-uni-app-x-zh
通知
144
Star
2
Fork
33
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
9
列表
看板
标记
里程碑
合并请求
11
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
unidocs-uni-app-x-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
9
Issue
9
列表
看板
标记
里程碑
合并请求
11
合并请求
11
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
0f23b28e
编写于
5月 21, 2024
作者:
D
DCloud_LXH
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: 补充组件描述
上级
cf8cb27f
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
72 addition
and
55 deletion
+72
-55
docs/.vuepress/utils/vueJson.json
docs/.vuepress/utils/vueJson.json
+1
-1
docs/collocation/app.md
docs/collocation/app.md
+8
-42
docs/page.md
docs/page.md
+12
-3
docs/vue/component.md
docs/vue/component.md
+51
-9
未找到文件。
docs/.vuepress/utils/vueJson.json
浏览文件 @
0f23b28e
因为 它太大了无法显示 source diff 。你可以改为
查看blob
。
docs/collocation/app.md
浏览文件 @
0f23b28e
...
@@ -23,42 +23,8 @@
...
@@ -23,42 +23,8 @@
|onExit|监听应用退出|app-uvue-android 3.9+|
|onExit|监听应用退出|app-uvue-android 3.9+|
**示例代码**
**示例代码**
```
html
<script
lang=
"uts"
>
<!-- VUEJSON.E_App.example.code -->
// 只能在App.vue里监听应用的生命周期
export
default
{
onLaunch
:
function
(
options
)
{
console
.
log
(
'
App Launch
'
)
console
.
log
(
'
应用启动路径:
'
,
options
.
path
)
},
onShow
:
function
(
options
)
{
console
.
log
(
'
App Show
'
)
console
.
log
(
'
应用启动路径:
'
,
options
.
path
)
},
onHide
:
function
()
{
console
.
log
(
'
App Hide
'
)
},
onLastPageBackPress
:
function
()
{
console
.
log
(
'
App LastPageBackPress
'
)
// 2秒内连按2次back,退出app
if
(
firstBackTime
==
0
)
{
uni
.
showToast
({
title
:
'
再按一次退出应用
'
,
position
:
'
bottom
'
,
})
firstBackTime
=
Date
.
now
()
setTimeout
(()
=>
{
firstBackTime
=
0
},
2000
)
}
else
if
(
Date
.
now
()
-
firstBackTime
<
2000
)
{
firstBackTime
=
Date
.
now
()
uni
.
exit
()
}
// 还有一些应用按1次back直接将应用切到后台,详见https://doc.dcloud.net.cn/uni-app-x/api/exit.html#back
}
}
</script>
```
**注意**
**注意**
-
**应用生命周期仅可在`App.uvue`中监听,在其它页面监听无效**
。
-
**应用生命周期仅可在`App.uvue`中监听,在其它页面监听无效**
。
...
...
docs/page.md
浏览文件 @
0f23b28e
...
@@ -111,8 +111,7 @@ uvue页面基于 vue 单文件组件规范。一个页面内,有3个根节点
...
@@ -111,8 +111,7 @@ uvue页面基于 vue 单文件组件规范。一个页面内,有3个根节点
<!-- PAGEINSTANCE.lifeCycle.compatibility -->
<!-- PAGEINSTANCE.lifeCycle.compatibility -->
在 Vue 中,页面也是一种组件,所以也支持
[
组件生命周期
](
./vue/options-api.md#page-component-options
)
。
\
在 Vue 中,页面也是一种组件,所以也支持
[
组件生命周期
](
./vue/options-api.md#page-component-options
)
。
示例代码,
[
详见
](
./vue/composition-api.md#page-lifecycle-compatibility
)
### 页面onLoad生命周期@onload
### 页面onLoad生命周期@onload
...
@@ -166,11 +165,21 @@ onShow和onHide是成对出现的。
...
@@ -166,11 +165,21 @@ onShow和onHide是成对出现的。
在组合式API中,组件可以监听应用和页面的生命周期。但由于应用和页面都有onShow和onHide,导致重名。所以在组合式的组件中监听页面的显示隐藏,改为了onPageShow和onPageHide。
在组合式API中,组件可以监听应用和页面的生命周期。但由于应用和页面都有onShow和onHide,导致重名。所以在组合式的组件中监听页面的显示隐藏,改为了onPageShow和onPageHide。
### 页面生命周期示例 @lifecycle-example
[
详情
](
<
!-- VUEJSON.E_lifecycle.page_page-composition.gitUrl --
>
)
::: preview
<!-- VUEJSON.E_lifecycle.page_page-composition.webUrl -->
<!-- VUEJSON.E_lifecycle.page_page-composition.code -->
:::
## 页面及组件生命周期流程图 @lifecycleflow
## 页面及组件生命周期流程图 @lifecycleflow
下图展示了一个新页面,从创建开始,包括其中的组件,完整的时序。
下图展示了一个新页面,从创建开始,包括其中的组件,完整的时序。
![](
https://web-ext-storage.dcloud.net.cn/doc/tutorial/uni-app-lifecycle-vue3.jpg
)
#{.zooming width=
10
00 margin=auto}
![](
https://web-ext-storage.dcloud.net.cn/doc/tutorial/uni-app-lifecycle-vue3.jpg
)
#{.zooming width=
6
00 margin=auto}
1.
uni-app x框架,首先根据pages.json的配置,创建页面
1.
uni-app x框架,首先根据pages.json的配置,创建页面
...
...
docs/vue/component.md
浏览文件 @
0f23b28e
...
@@ -15,9 +15,37 @@
...
@@ -15,9 +15,37 @@
组件还可以封装方法、事件、插槽,提供了组件的生命周期,提供了组件和页面的互通信机制,满足了各种高级需求。
组件还可以封装方法、事件、插槽,提供了组件的生命周期,提供了组件和页面的互通信机制,满足了各种高级需求。
## 组件内容构成 @component-structure
uni-app x 组件基于 vue 单文件组件规范,一个组件内,有 3 个根节点标签:
-
`<template>`
:组件的模板内容
-
`<script>`
:组件的脚本代码
-
`<style>`
:组件的样式
### 和页面的区别 @component-page-difference
组件的内容构成和页面大体上一致,但是在组件中,不支持
`onLoad`
、
`onShow`
等
[
页面生命周期
](
../page.md#lifecycle
)
,而是支持
[
组件生命周期
](
#component-lifecycle
)
## 创建及引用组件 @create-and-import-component
## 创建及引用组件 @create-and-import-component
### easycom
### 创建组件 @create-component
#### easycom
1.
在
`项目根目录/components`
目录上右键(如果没有,在根目录新建一个
`components`
目录即可),选择
`新建组件`
,输入组件名称,选择一个模板;可勾选创建同名目录,将组件放在同名目录下。
2.
在
`项目根目录/uni_modules`
目录上右键(如果没有,在根目录新建一个
`uni_modules`
目录即可),选择
`新建uni_modules插件`
,输入
`插件ID`
,分类选择
`前端组件-通用组件`
;将组件放在和插件ID同名的目录下。
#### 创建自定义组件 @create-custom-component
3.
在项目
`pages 目录`
下的任意地方创建
`.uvue/.vue`
文件并编写组件代码
::: warning 注意事项
uni-app x 项目支持使用
`.vue`
、
`.uvue`
文件作为组件使用,但同文件名的两个文件同时存在,
`.uvue`
文件会优先编译。
:::
### 引用组件 @import-component
#### easycom
传统vue组件,需要安装、引用、注册,三个步骤后才能使用组件。
`easycom`
将其精简为一步。
传统vue组件,需要安装、引用、注册,三个步骤后才能使用组件。
`easycom`
将其精简为一步。
...
@@ -49,14 +77,14 @@ uni_module有详细的专项文档,请另行查阅[uni_module规范](https://u
...
@@ -49,14 +77,14 @@ uni_module有详细的专项文档,请另行查阅[uni_module规范](https://u
如果你的组件不满足easycom标准的目录规范,还有一种办法是在
[
pages.json
](
../collocation/pagesjson.md#pages-easycom
)
里声明自己的目录规则,以便编译器查找到你的组件。自定义easycom路径规则的详细教程
[
详见
](
https://uniapp.dcloud.net.cn/collocation/pages.html#easycom
)
如果你的组件不满足easycom标准的目录规范,还有一种办法是在
[
pages.json
](
../collocation/pagesjson.md#pages-easycom
)
里声明自己的目录规则,以便编译器查找到你的组件。自定义easycom路径规则的详细教程
[
详见
](
https://uniapp.dcloud.net.cn/collocation/pages.html#easycom
)
#### easycom组件的类型规范 @easycom-component-type
####
#
easycom组件的类型规范 @easycom-component-type
组件标签名首字母大写,
`驼峰+ComponentPublicInstance`
,如:
组件标签名首字母大写,
`驼峰+ComponentPublicInstance`
,如:
`<test/>`
类型为:TestComponentPublicInstance
`<test/>`
类型为:TestComponentPublicInstance
`<uni-data-checkbox/>`
类型为:UniDataCheckboxComponentPublicInstance
`<uni-data-checkbox/>`
类型为:UniDataCheckboxComponentPublicInstance
### 手动引入组件 @manual-import-component
###
#
手动引入组件 @manual-import-component
不符合 easycom 规范的组件,则需要手动引入:
不符合 easycom 规范的组件,则需要手动引入:
...
@@ -88,7 +116,7 @@ export default {
...
@@ -88,7 +116,7 @@ export default {
</
script
>
</
script
>
```
```
#### 手动引入组件的类型规范 @manual-import-component-type
####
#
手动引入组件的类型规范 @manual-import-component-type
类型为:ComponentPublicInstance
类型为:ComponentPublicInstance
...
@@ -320,11 +348,7 @@ Uni`组件名(驼峰)`Element
...
@@ -320,11 +348,7 @@ Uni`组件名(驼峰)`Element
-
目前uts组件,即封装原生ui给uni-app或uni-app x的页面中使用,类型与内置组件的 Uni
`组件名(驼峰)`
Element 方式相同。目前没有代码提示。
-
目前uts组件,即封装原生ui给uni-app或uni-app x的页面中使用,类型与内置组件的 Uni
`组件名(驼峰)`
Element 方式相同。目前没有代码提示。
### 组件监听页面生命周期 @component-page-lifecycle
### 组件监听应用、页面生命周期 @component-page-lifecycle
[
示例
](
#component-lifecycle
)
## 组件的生命周期 @component-lifecycle
> 选项式 API 和 组件式 API 在监听页面生命周期时有所不同
> 选项式 API 和 组件式 API 在监听页面生命周期时有所不同
>
>
...
@@ -332,6 +356,22 @@ Uni`组件名(驼峰)`Element
...
@@ -332,6 +356,22 @@ Uni`组件名(驼峰)`Element
>
>
> 具体请查看 [页面生命周期](../page.md#lifecycle)
> 具体请查看 [页面生命周期](../page.md#lifecycle)
示例
[
详情
](
<
!-- VUEJSON.E_lifecycle.page_monitor-page-lifecycle-options.gitUrl --
>
)
::: preview
<!-- VUEJSON.E_lifecycle.page_page-options.webUrl -->
> 选项式 API
<!-- VUEJSON.E_lifecycle.page_monitor-page-lifecycle-options.code -->
> 组合式 API
<!-- VUEJSON.E_lifecycle.page_monitor-page-lifecycle-composition.code -->
:::
## 组件的生命周期 @component-lifecycle
示例
[
详情
](
<
!-- VUEJSON.E_lifecycle.component_ChildComponentOptions.gitUrl --
>
)
示例
[
详情
](
<
!-- VUEJSON.E_lifecycle.component_ChildComponentOptions.gitUrl --
>
)
::: preview
<!-- VUEJSON.E_lifecycle.component_component-options.webUrl -->
::: preview
<!-- VUEJSON.E_lifecycle.component_component-options.webUrl -->
...
@@ -346,6 +386,8 @@ Uni`组件名(驼峰)`Element
...
@@ -346,6 +386,8 @@ Uni`组件名(驼峰)`Element
:::
:::
## [全局组件](./global-api.md#app-component)
## props
## props
-
支持
[
对象方式
](
https://cn.vuejs.org/guide/components/props.html#props-declaration
)
声明。从 4.0+ 支持字符串数组方式声明。使用字符串数组方式声明时,所有 prop 类型均为 any | null。
-
支持
[
对象方式
](
https://cn.vuejs.org/guide/components/props.html#props-declaration
)
声明。从 4.0+ 支持字符串数组方式声明。使用字符串数组方式声明时,所有 prop 类型均为 any | null。
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录