App.md 3.8 KB
Newer Older
雪洛's avatar
雪洛 已提交
1
`App.vue`是uni-app的主组件,所有页面都是在`App.vue`下进行切换的,是页面入口文件。但`App.vue`本身不是页面,这里不能编写视图元素,也就是没有`<template>`
Q
qiang 已提交
2 3 4 5

这个文件的作用包括:调用应用生命周期函数、配置全局样式、配置全局的存储globalData

应用生命周期仅可在`App.vue`中监听,在页面监听无效。
雪洛's avatar
雪洛 已提交
6

D
DCloud_LXH 已提交
7
## 应用生命周期@applifecycle
Q
qiang 已提交
8

D
DCloud_LXH 已提交
9
``uni-app`` 支持如下应用生命周期函数:
Q
qiang 已提交
10

D
DCloud_LXH 已提交
11 12 13 14 15 16 17 18 19 20 21 22
|函数名|说明|
|:-|:-|
|onLaunch|当``uni-app`` 初始化完成时触发(全局只触发一次)|
|onShow|当 ``uni-app`` 启动,或从后台进入前台显示|
|onHide|当 ``uni-app`` 从前台进入后台|
|onError|当 ``uni-app`` 报错时触发|
|onUniNViewMessage|对 ``nvue`` 页面发送的数据进行监听,可参考 [nvue 向 vue 通讯](https://uniapp.dcloud.io/tutorial/nvue-api?id=communication)|
|onUnhandledRejection|对未处理的 Promise 拒绝事件监听函数(2.8.1+)|
|onPageNotFound|页面不存在监听函数|
|onThemeChange|监听系统主题变化|

**示例代码**
Q
qiang 已提交
23
```html
D
DCloud_LXH 已提交
24 25 26 27 28 29 30 31 32 33 34 35 36 37
<script>
	// 只能在App.vue里监听应用的生命周期
	export default {
		onLaunch: function() {
			console.log('App Launch')
		},
		onShow: function() {
			console.log('App Show')
		},
		onHide: function() {
			console.log('App Hide')
		}
	}
</script>
Q
qiang 已提交
38 39 40 41
```

**注意**
- **应用生命周期仅可在`App.vue`中监听,在其它页面监听无效**
Y
yurj26 已提交
42
- 以组合式 API 使用时,在 Vue2 和 Vue3 中存在一定区别,请分别参考:[Vue2 组合式 API 使用文档](/tutorial/vue-composition-api.html)[Vue3 组合式 API 使用文档](/tutorial/vue3-composition-api.html)
雪洛's avatar
雪洛 已提交
43
- 应用启动参数,可以在API `uni.getLaunchOptionsSync`获取,[详见](https://uniapp.dcloud.net.cn/api/plugins/getLaunchOptionsSync.html#getlaunchoptionssync)
Q
qiang 已提交
44 45
- onlaunch里进行页面跳转,如遇白屏报错,请参考[https://ask.dcloud.net.cn/article/35942](https://ask.dcloud.net.cn/article/35942)
- `App.vue` 不能写模板
D
DCloud_LXH 已提交
46
- onPageNotFound 页面实际上已经打开了(比如通过分享卡片、小程序码)且发现页面不存在,才会触发,api 跳转不存在的页面不会触发(如 uni.navigateTo)
Q
qiang 已提交
47

D
DCloud_LXH 已提交
48
## globalData
Q
qiang 已提交
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
小程序有globalData,这是一种简单的全局变量机制。这套机制在uni-app里也可以使用,并且全端通用。

**以下是 App.vue 中定义globalData的相关配置:**

```html
<script>  
    export default {  
        globalData: {  
            text: 'text'  
        }
    }  
</script>  
```

js中操作globalData的方式如下:
`getApp().globalData.text = 'test'`

Q
qiang 已提交
66
在应用onLaunch时,getApp对象还未获取,暂时可以使用this.globalData获取globalData。
Q
qiang 已提交
67 68 69 70 71 72 73

如果需要把globalData的数据绑定到页面上,可在页面的onShow页面生命周期里进行变量重赋值。

nvue的weex编译模式中使用globalData的话,由于weex生命周期不支持onShow,但熟悉5+的话,可利用监听webview的addEventListener show事件实现onShow效果,或者直接使用weex生命周期中的beforeCreate。但建议开发者使用uni-app编译模式,而不是weex编译模式。

globalData是简单的全局变量,如果使用状态管理,请使用`vuex`(main.js中定义)

D
DCloud_LXH 已提交
74
## 全局样式
Q
qiang 已提交
75 76 77 78 79 80 81 82 83 84
`App.vue`中,可以定义一些全局通用样式,例如需要加一个通用的背景色,首屏页面渲染的动画等都可以写在App.vue中。

注意如果工程下同时有vue和nvue文件,全局样式的所有css会应用于所有文件,而nvue支持的css有限,编译器会在控制台报警,提示某些css无法在nvue中支持。此时需要把nvue不支持的css写在单独的条件编译里。如:
```html
<style>
    /* #ifndef APP-PLUS-NVUE */
    @import './common/uni.css';
    /* #endif*/
</style>
```