app.md 3.0 KB
Newer Older
D
DCloud_LXH 已提交
1 2 3 4 5 6 7 8 9 10
# App.uvue

`App.uvue`是uni-app-x的主组件。

所有页面都是在`App.uvue`下进行切换的,是应用入口文件。但`App.uvue`本身不是页面,这里不能编写视图元素,也就是没有`<template>`

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

应用生命周期仅可在`App.uvue`中监听,在页面监听无效。

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
11
`App.uvue`仅支持选项式,暂不支持组合式写法。
W
wanganxp 已提交
12

D
DCloud_LXH 已提交
13 14 15 16 17 18
## 应用生命周期@applifecycle

`uni-app-x` 支持如下应用生命周期函数:

|函数名|说明|平台兼容|
|:-|:-|:-|
19
|onLaunch|当`uni-app-x` 初始化完成时触发(全局只触发一次),参数为应用启动参数,同 [uni.getLaunchOptionsSync](../api/launch.md#getlaunchoptionssync) 的返回值||
H
hdx 已提交
20
|onShow|当 `uni-app-x` 启动,或从后台进入前台显示,参数为应用启动参数||
W
x  
wanganxp 已提交
21
|onHide|当 `uni-app-x` 从前台进入后台,包括手机息屏||
D
DCloud_LXH 已提交
22 23
|onLastPageBackPress|最后一个页面按下Android back键,常用于自定义退出|app-uvue-android 3.9+|
|onExit|监听应用退出|app-uvue-android 3.9+|
24
|onError|监听应用发生脚本错误或 API 调用报错|4.21+|
D
DCloud_LXH 已提交
25 26

**示例代码**
D
DCloud_LXH 已提交
27 28

<!-- VUEJSON.E_App.example.code -->
D
DCloud_LXH 已提交
29 30 31

**注意**
- **应用生命周期仅可在`App.uvue`中监听,在其它页面监听无效**
32
- 应用启动参数,可以在API `uni.getLaunchOptionsSync`获取,[详见](../api/launch.md#getlaunchoptionssync)
DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
33
- 由于Android的`uni.exit()`[热退出](../api/exit.md),此时很多代码逻辑仍然在运行,有些on的事件监听并没有off,需要开发者在onExit生命周期中编写代码处理。比如在app的onLaunch里通过onXX监听了某事件,那么就需要在onExit里调用offXX取消某事件的监听,否则反复热退出、启动,会多次on而不会off,这会引发内存泄露。
D
DCloud_LXH 已提交
34 35 36

## globalData

W
wanganxp 已提交
37
> HBuilderX 3.99+
D
DCloud_LXH 已提交
38

W
wanganxp 已提交
39
小程序有 globalData,这是一种简单的全局变量机制。这套机制在 uni-app-x 里也可以使用,并且全端通用。
D
DCloud_LXH 已提交
40 41 42 43 44

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

```ts
<script lang="uts">
D
DCloud_LXH 已提交
45 46
  export default {
    globalData: {
D
DCloud_LXH 已提交
47 48
      str: 'global data str',
      num: 123,
D
DCloud_LXH 已提交
49
      bool: true
D
DCloud_LXH 已提交
50
    }
D
DCloud_LXH 已提交
51 52
  }
</script>
D
DCloud_LXH 已提交
53 54 55 56 57 58
```

页面或组件中通过 `getApp().globalData` 访问。

```ts
<script lang="uts">
D
DCloud_LXH 已提交
59
  export default {
D
DCloud_LXH 已提交
60 61 62 63 64 65 66 67 68 69 70 71 72 73
    methods: {
      getGlobalData() {
        const app = getApp()
        this.globalDataStr = app.globalData.str
        this.globalDataNum = app.globalData.num
        this.globalDataBool = app.globalData.bool
      }
    }
  }
</script>
```

**注意:** `uni-app x``globalData` 的数据结构与类型通过 `App.uvue` 中的 `globalData` 初始值定义,后续只能读取或修改,不能新增或删除。

W
wanganxp 已提交
74
globalData是简单的全局变量,其他状态管理方式,可参考文档[全局变量和状态管理](../tutorial/store.md)
D
DCloud_LXH 已提交
75 76 77

## 全局样式

DCloud_Heavensoft's avatar
DCloud_Heavensoft 已提交
78
`App.uvue`中,可以定义一些全局通用样式,这里定义的class,每个页面都可以直接使用。