├── dist 編譯結(jié)果目錄
├── config 配置目錄
| ├── dev.js 開發(fā)時(shí)配置
| ├── index.js 默認(rèn)配置
| └── prod.js 打包時(shí)配置
├── src 源碼目錄
| ├── pages 頁(yè)面文件目錄
| | ├── index index 頁(yè)面目錄
| | | ├── index.js index 頁(yè)面邏輯
| | | └── index.css index 頁(yè)面樣式
| ├── app.css 項(xiàng)目總通用樣式
| └── app.js 項(xiàng)目入口文件
└── package.json
入口文件默認(rèn)是 src
目錄下的 app.js
。
一個(gè)普通的入口文件示例如下
import Taro, { Component } from '@tarojs/taro'
import Index from './pages/index'
import './app.scss'
class App extends Component {
// 項(xiàng)目配置
config = {
pages: [
'pages/index/index'
],
window: {
backgroundTextStyle: 'light',
navigationBarBackgroundColor: '#fff',
navigationBarTitleText: 'WeChat',
navigationBarTextStyle: 'black'
}
}
componentWillMount () {}
componentDidMount () {}
componentDidShow () {}
componentDidHide () {}
render () {
return (
<Index />
)
}
}
可以看出入口文件也是 React
風(fēng)格的寫法,首先需要引用依賴 @tarojs/taro
,這是 Taro 方案的基礎(chǔ)框架,在這里我們繼承了 Component
組件基類。
通常入口文件會(huì)包含一個(gè) config
配置項(xiàng),這個(gè)配置是整個(gè)應(yīng)用的全局的配置,配置規(guī)范基于微信小程序的全局配置進(jìn)行制定,所有平臺(tái)進(jìn)行統(tǒng)一。
入口文件中的全局配置,在編譯后將生成全局配置文件 app.json
。
Taro 中全局配置所包含的配置項(xiàng)及各端支持程度如下
屬性 | 類型 | 必填 | 描述 | 微信小程序 | 百度小程序 | 字節(jié)跳動(dòng)小程序 | 支付寶小程序 | H5 | RN |
---|---|---|---|---|---|---|---|---|---|
pages | String Array | 是 | 頁(yè)面路徑列表 | ?? | ?? | ?? | ?? | ?? | ?? |
window | Object | 否 | 全局的默認(rèn)窗口表現(xiàn) | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 |
tabBar | Object | 否 | 底部 tab 欄的表現(xiàn) | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 | 具體支持程度見下方 |
networkTimeout | Object | 否 | 網(wǎng)絡(luò)超時(shí)時(shí)間 | ?? | ? | ? | ? | ? | ? |
debug | Boolean | 否 | 是否開啟 debug 模式,默認(rèn)關(guān)閉 | ?? | ? | ?? | ? | ? | ? |
functionalPages | Boolean | 否 | 是否啟用插件功能頁(yè),默認(rèn)關(guān)閉 | ??(基礎(chǔ)庫(kù) 2.1.0 以上) | ? | ? | ? | ? | ? |
subPackages | Object Array | 否 | 分包結(jié)構(gòu)配置 | ??(基礎(chǔ)庫(kù) 1.7.3 以上) | ?? | ? | ? | ?? | ?? |
workers | String | 否 | Worker 代碼放置的目錄 | ??(基礎(chǔ)庫(kù) 1.9.90 以上) | ? | ? | ? | ? | ? |
requiredBackgroundModes | String Array | 否 | 需要在后臺(tái)使用的能力,如「音樂(lè)播放」 | ?? | ? | ? | ? | ? | ? |
plugins | Object | 否 | 使用到的插件 | ??(基礎(chǔ)庫(kù) 1.9.6 以上) | ? | ? | ? | ? | ? |
preloadRule | Object | 否 | 分包預(yù)下載規(guī)則 | ??(基礎(chǔ)庫(kù) 2.3.0 以上) | ?? | ? | ? | ? | ? |
resizable | Boolean | 否 | iPad 小程序是否支持屏幕旋轉(zhuǎn),默認(rèn)關(guān)閉 | ??(基礎(chǔ)庫(kù) 2.3.0 以上) | ? | ? | ? | ? | ? |
navigateToMiniProgramAppIdList | String Array | 否 | 需要跳轉(zhuǎn)的小程序列表,詳見 wx.navigateToMiniProgram | ??(基礎(chǔ)庫(kù) 2.4.0 以上) | ? | ? | ? | ? | ? |
usingComponents | Object | 否 | 全局自定義組件配置 | ??(開發(fā)者工具 1.02.1810190) | ? | ? | ? | ? | ? |
permission | Object | 否 | 小程序接口權(quán)限相關(guān)設(shè)置 | ?? 微信客戶端 7.0.0 | ? | ? | ? | ? | ? |
用于指定小程序由哪些頁(yè)面組成,每一項(xiàng)都對(duì)應(yīng)一個(gè)頁(yè)面的 路徑 + 文件名
信息。文件名不需要寫文件后綴,框架會(huì)自動(dòng)去尋找對(duì)應(yīng)位置的文件進(jìn)行處理。
數(shù)組的第一項(xiàng)代表小程序的初始頁(yè)面(首頁(yè))。小程序中新增/減少頁(yè)面,都需要對(duì) pages 數(shù)組進(jìn)行修改。
如開發(fā)目錄為:
├── app.js
├── app.json
├── app.wxss
├── pages
│ │── index
│ │ ├── index.wxml
│ │ ├── index.js
│ │ ├── index.json
│ │ └── index.wxss
│ └── logs
│ ├── logs.wxml
│ └── logs.js
└── utils
則需要在入口文件配置中寫
class App extends Component {
// 項(xiàng)目配置
config = {
pages: [
'pages/index/index',
'pages/logs/logs'
]
}
...
}
用于設(shè)置小程序的狀態(tài)欄、導(dǎo)航條、標(biāo)題、窗口背景色,其配置項(xiàng)如下。
屬性 | 類型 | 默認(rèn)值 | 描述 |
---|---|---|---|
navigationBarBackgroundColor | HexColor(十六進(jìn)制顏色值) | #000000 | 導(dǎo)航欄背景顏色,如 #000000 |
navigationBarTextStyle | String | white | 導(dǎo)航欄標(biāo)題顏色,僅支持 black / white |
navigationBarTitleText | String | 導(dǎo)航欄標(biāo)題文字內(nèi)容 | |
navigationStyle | String | default | 導(dǎo)航欄樣式,僅支持以下值:default 默認(rèn)樣式;custom 自定義導(dǎo)航欄,只保留右上角膠囊按鈕 |
backgroundColor | String | 窗口的背景色 | |
backgroundTextStyle | String | dark | 下拉 loading 的樣式,僅支持 dark / light |
backgroundColorTop | String | #ffffff | 頂部窗口的背景色,僅 iOS 支持 |
backgroundColorBottom | String | #ffffff | 底部窗口的背景色,僅 iOS 支持 |
enablePullDownRefresh | boolean | false | 是否開啟當(dāng)前頁(yè)面的下拉刷新。 |
onReachBottomDistance | Number | 50 | 頁(yè)面上拉觸底事件觸發(fā)時(shí)距頁(yè)面底部距離,單位為 px |
pageOrientation | String | portrait | 屏幕旋轉(zhuǎn)設(shè)置,支持 auto / portrait / landscape 詳見 響應(yīng)顯示區(qū)域變化 |
各端支持程度如下
屬性 | 微信小程序 | 百度小程序 | 字節(jié)跳動(dòng)小程序 | 支付寶小程序 | H5 | RN |
---|---|---|---|---|---|---|
navigationBarBackgroundColor | ?? | ?? | ?? | ?? | ?? | ?? |
navigationBarTextStyle | ?? | ?? | ?? | ? | ?? | ?? |
navigationBarTitleText | ?? | ?? | ?? | ?? | ?? | ?? |
navigationStyle | ??(微信客戶端 6.6.0) | ??(百度 App 版本 11.1.0) | ?? | ? | ? | ? |
backgroundColor | ?? | ?? | ?? | ? | ? | ?? |
backgroundTextStyle | ?? | ?? | ?? | ? | ? | ? |
backgroundColorTop | ??(微信客戶端 6.5.16) | ? | ?? | ? | ? | ? |
backgroundColorBottom | ??(微信客戶端 6.5.16) | ? | ?? | ? | ? | ? |
enablePullDownRefresh | ?? | ?? | ?? | ?? | ? | ? |
onReachBottomDistance | ?? | ?? | ?? | ? | ? | ? |
pageOrientation | ??2.4.0 (auto) / 2.5.0 (landscape) | ? | ? | ? | ? | ? |
微信小程序中,關(guān)于navigationStyle
- 客戶端 7.0.0 以下版本,navigationStyle 只在 app.json 中生效。
- 客戶端 6.7.2 版本開始,navigationStyle: custom 對(duì) <web-view> 組件無(wú)效
- 開啟 custom 后,低版本客戶端需要做好兼容。開發(fā)者工具基礎(chǔ)庫(kù)版本切到 1.7.0(不代表最低版本,只供調(diào)試用)可方便切到舊視覺(jué)
配置示例如下:
class App extends Component {
// 項(xiàng)目配置
config = {
pages: [
'pages/index/index',
'pages/logs/logs'
],
window: {
navigationBarBackgroundColor: '#ffffff',
navigationBarTextStyle: 'black',
navigationBarTitleText: '微信接口功能演示',
backgroundColor: '#eeeeee',
backgroundTextStyle: 'light'
}
}
...
}
如果小程序是一個(gè)多 tab 應(yīng)用(客戶端窗口的底部或頂部有 tab 欄可以切換頁(yè)面),可以通過(guò) tabBar 配置項(xiàng)指定 tab 欄的表現(xiàn),以及 tab 切換時(shí)顯示的對(duì)應(yīng)頁(yè)面。
其配置項(xiàng)如下
屬性 | 類型 | 必填 | 默認(rèn)值 | 描述 |
---|---|---|---|---|
color | HexColor(十六進(jìn)制顏色值) | 是 | tab 上的文字默認(rèn)顏色,僅支持十六進(jìn)制顏色 | |
selectedColor | HexColor(十六進(jìn)制顏色值) | 是 | tab 上的文字選中時(shí)的顏色,僅支持十六進(jìn)制顏色 | |
backgroundColor | HexColor(十六進(jìn)制顏色值) | 是 | tab 的背景色,僅支持十六進(jìn)制顏色 | |
borderStyle | String | 是 | black | tabbar 上邊框的顏色, 僅支持 black / white |
list | Array | 是 | tab 的列表,詳見 list 屬性說(shuō)明,最少 2 個(gè)、最多 5 個(gè) tab | |
position | String | 否 | bottom | tabBar的位置,僅支持 bottom / top |
custom | Boolean | 否 | false | 自定義 tabBar |
各端支持程度如下
屬性 | 微信小程序 | 百度小程序 | 字節(jié)跳動(dòng)小程序 | 支付寶小程序 | H5 | RN |
---|---|---|---|---|---|---|
color | ?? | ?? | ?? | ?? | ?? | ?? |
selectedColor | ?? | ?? | ?? | ?? | ?? | ?? |
backgroundColor | ?? | ?? | ?? | ?? | ?? | ?? |
borderStyle | ?? | ?? | ?? | ? | ?? | ?? |
list | ?? | ?? | ?? | ?? | ?? | ?? |
position | ?? | ? | ?? | ? | ? | ? |
custom | ??(基礎(chǔ)庫(kù) 2.5.0 以上) | ? | ? | ? | ? | ? |
其中 list 接受一個(gè)數(shù)組,只能配置最少 2 個(gè)、最多 5 個(gè) tab。tab 按數(shù)組的順序排序,每個(gè)項(xiàng)都是一個(gè)對(duì)象,其屬性值如下:
屬性 | 類型 | 必填 | 描述 |
---|---|---|---|
pagePath | String | 是 | 頁(yè)面路徑,必須在 pages 中先定義 |
text | String | 是 | tab 上按鈕文字 |
iconPath | String | 否 | 圖片路徑,icon 大小限制為40kb,建議尺寸為 81px * 81px,不支持網(wǎng)絡(luò)圖片。 當(dāng) position 為 top 時(shí),不顯示 icon。 |
selectedIconPath | String | 否 | 選中時(shí)的圖片路徑,icon 大小限制為40kb,建議尺寸為 81px * 81px,不支持網(wǎng)絡(luò)圖片。 當(dāng) position 為 top 時(shí),不顯示 icon。 |
只在微信小程序上支持
各類網(wǎng)絡(luò)請(qǐng)求的超時(shí)時(shí)間,單位均為毫秒。
屬性 | 類型 | 必填 | 默認(rèn)值 | 描述 |
---|---|---|---|---|
request | Number | 否 | 60000 | Taro.request 的超時(shí)時(shí)間,單位:毫秒 |
connectSocket | Number | 否 | 60000 | Taro.connectSocket 的超時(shí)時(shí)間,單位:毫秒 |
uploadFile | Number | 否 | 60000 | Taro.uploadFile 的超時(shí)時(shí)間,單位:毫秒 |
downloadFile | Number | 否 | 60000 | Taro.downloadFile 的超時(shí)時(shí)間,單位:毫秒 |
可以在開發(fā)者工具中開啟 debug 模式,在開發(fā)者工具的控制臺(tái)面板,調(diào)試信息以 info 的形式給出,其信息有 Page 的注冊(cè),頁(yè)面路由,數(shù)據(jù)更新,事件觸發(fā)等??梢詭椭_發(fā)者快速定位一些常見的問(wèn)題。
微信小程序基礎(chǔ)庫(kù) 2.1.0 開始支持
啟用插件功能頁(yè)時(shí),插件所有者小程序需要設(shè)置其 functionalPages
為 true
微信客戶端 6.6.0 ,基礎(chǔ)庫(kù) 1.7.3 及以上版本支持
百度小程序支持
H5 和 RN 會(huì)把subPackages
合入pages
啟用分包加載時(shí),聲明項(xiàng)目分包結(jié)構(gòu)
微信小程序基礎(chǔ)庫(kù) 1.9.90 開始支持
使用 Worker 處理多線程任務(wù)時(shí),設(shè)置 Worker 代碼放置的目錄
微信客戶端 6.7.2 及以上版本支持
申明需要后臺(tái)運(yùn)行的能力,類型為數(shù)組。目前支持以下項(xiàng)目:
audio
: 后臺(tái)音樂(lè)播放class App extends Component {
// 項(xiàng)目配置
config = {
pages: [
'pages/index/index',
'pages/logs/logs'
],
requiredBackgroundModes: ['audio']
}
...
}
注:在此處申明了后臺(tái)運(yùn)行的接口,開發(fā)版和體驗(yàn)版上可以直接生效,正式版還需通過(guò)審核。
微信小程序基礎(chǔ)庫(kù) 1.9.6 開始支持
聲明小程序需要使用的 插件
微信小程序基礎(chǔ)庫(kù) 2.3.0 開始支持
聲明分包預(yù)下載的規(guī)則
微信小程序基礎(chǔ)庫(kù) 2.3.0 開始支持
在 iPad 上運(yùn)行的小程序可以設(shè)置支持屏幕旋轉(zhuǎn)
微信小程序基礎(chǔ)庫(kù) 2.4.0 開始支持
當(dāng)小程序需要使用 Taro.navigateToMiniProgram 接口跳轉(zhuǎn)到其他小程序時(shí),需要先在配置文件中聲明需要跳轉(zhuǎn)的小程序 appId 列表,最多允許填寫 10 個(gè)
微信開發(fā)者工具 1.02.1810190 及以上版本支持
在此處聲明的自定義組件視為全局自定義組件,在小程序內(nèi)的頁(yè)面或自定義組件中可以直接使用而無(wú)需再聲明
微信客戶端 7.0.0 及以上版本支持
微信小程序接口權(quán)限相關(guān)設(shè)置。字段類型為 Object,結(jié)構(gòu)為:
屬性 | 類型 | 必填 | 默認(rèn)值 | 描述 |
---|---|---|---|---|
scope.userLocation | PermissionObject | 否 | 位置相關(guān)權(quán)限聲明 |
PermissionObject 結(jié)構(gòu)
屬性 | 類型 | 必填 | 默認(rèn)值 | 描述 |
---|---|---|---|---|
desc | string | 是 | 小程序獲取權(quán)限時(shí)展示的接口用途說(shuō)明。最長(zhǎng) 30 個(gè)字符 |
class App extends Component {
// 項(xiàng)目配置
config = {
pages: [
'pages/index/index',
'pages/logs/logs'
],
permission: {
'scope.userLocation': {
desc: '你的位置信息將用于小程序位置接口的效果展示'
}
}
}
...
}
而且由于入口文件繼承自 Component
組件基類,它同樣擁有組件生命周期,但因?yàn)槿肟谖募奶厥庑裕纳芷诓⒉煌暾?,具體如下
在微信/百度/字節(jié)跳動(dòng)/支付寶小程序中這一生命周期方法對(duì)應(yīng) app 的
onLaunch
監(jiān)聽程序初始化,初始化完成時(shí)觸發(fā)(全局只觸發(fā)一次)
在此生命周期中通過(guò) this.$router.params
,可以訪問(wèn)到程序初始化參數(shù)
參數(shù)格式如下
屬性 | 類型 | 說(shuō)明 | 微信小程序 | 百度小程序 | 字節(jié)跳動(dòng)小程序 | 支付寶小程序 | H5 | RN |
---|---|---|---|---|---|---|---|---|
path | string | 啟動(dòng)小程序的路徑 | ?? | ?? | ?? | ?? | ? | ? |
scene | number | 啟動(dòng)小程序的場(chǎng)景值 | ?? | ?? | ?? | ? | ? | ? |
query | Object | 啟動(dòng)小程序的 query 參數(shù) | ?? | ?? | ?? | ?? | ? | ? |
shareTicket | string | shareTicket,詳見獲取更多轉(zhuǎn)發(fā)信息 | ?? | ?? | ?? | ? | ? | ? |
referrerInfo | Object | 來(lái)源信息。從另一個(gè)小程序、公眾號(hào)或 App 進(jìn)入小程序時(shí)返回。否則返回 {} | ?? | ?? | ?? | ?? | ? | ? |
其中,場(chǎng)景值 scene,在微信小程序和百度小程序中存在區(qū)別,請(qǐng)分別參考 微信小程序文檔 和 百度小程序文檔
來(lái)源信息 referrerInfo 的數(shù)據(jù)結(jié)構(gòu)如下
屬性 | 類型 | 說(shuō)明 | 微信小程序 | 百度小程序 | 字節(jié)跳動(dòng)小程序 | 支付寶小程序 |
---|---|---|---|---|---|---|
appId | string | 來(lái)源小程序,或者公眾號(hào)(微信中) | ?? | ?? | ?? | ?? |
extraData | Object | 來(lái)源小程序傳過(guò)來(lái)的數(shù)據(jù),微信和百度小程序在scene=1037或1038時(shí)支持 | ?? | ?? | ?? | ?? |
sourceServiceId | string | 來(lái)源插件,當(dāng)處于插件運(yùn)行模式時(shí)可見 | ? | ? | ? | ??(基礎(chǔ)庫(kù)版本 1.11.0) |
在微信/百度/字節(jié)跳動(dòng)/支付寶小程序中這一生命周期方法對(duì)應(yīng) app 的
onLaunch
,在componentWillMount
后執(zhí)行
監(jiān)聽程序初始化,初始化完成時(shí)觸發(fā)(全局只觸發(fā)一次)
在此生命周期中也可以通過(guò) this.$router.params
,訪問(wèn)到程序初始化參數(shù),與 componentWillMount
中一致
在微信/百度/字節(jié)跳動(dòng)/支付寶小程序中這一生命周期方法對(duì)應(yīng)
onShow
,在 H5/RN 中同步實(shí)現(xiàn)
程序啟動(dòng),或從后臺(tái)進(jìn)入前臺(tái)顯示時(shí)觸發(fā),微信小程序中也可以使用 Taro.onAppShow
綁定監(jiān)聽
在此生命周期中通過(guò) this.$router.params
,可以訪問(wèn)到程序初始化參數(shù)
參數(shù)與 componentWillMount
中獲取的基本一致,但百度小程序中補(bǔ)充兩個(gè)參數(shù)如下
屬性 | 類型 | 說(shuō)明 | 最低版本 |
---|---|---|---|
entryType | string | 展現(xiàn)的來(lái)源標(biāo)識(shí),取值為 user/ schema /sys : user:表示通過(guò)home前后 切換或解鎖屏幕等方式調(diào)起; schema:表示通過(guò)協(xié)議調(diào)起; sys:其它 | 2.10.7 |
appURL | string | 展現(xiàn)時(shí)的調(diào)起協(xié)議,僅當(dāng)entryType值為 schema 時(shí)存在 | 2.10.7 |
在微信/百度/字節(jié)跳動(dòng)/支付寶小程序中這一生命周期方法對(duì)應(yīng)
onHide
,在 H5/RN 中同步實(shí)現(xiàn)
程序從前臺(tái)進(jìn)入后臺(tái)時(shí)觸發(fā),微信小程序中也可以使用 Taro.onAppHide
綁定監(jiān)聽
在微信/百度/字節(jié)跳動(dòng)/支付寶小程序中這一生命周期方法對(duì)應(yīng)
onError
,H5/RN 中尚未實(shí)現(xiàn)
程序發(fā)生腳本錯(cuò)誤或 API 調(diào)用報(bào)錯(cuò)時(shí)觸發(fā),微信小程序中也可以使用 Taro.onError
綁定監(jiān)聽
在微信/字節(jié)跳動(dòng)小程序中這一生命周期方法對(duì)應(yīng)
onPageNotFound
,其他端尚未實(shí)現(xiàn)
微信小程序中,基礎(chǔ)庫(kù) 1.9.90 開始支持
程序要打開的頁(yè)面不存在時(shí)觸發(fā),微信小程序中也可以使用 Taro.onPageNotFound
綁定監(jiān)聽
參數(shù)如下
屬性 | 類型 | 說(shuō)明 |
---|---|---|
path | string | 不存在頁(yè)面的路徑 |
query | Object | 打開不存在頁(yè)面的 query 參數(shù) |
isEntryPage | boolean | 是否本次啟動(dòng)的首個(gè)頁(yè)面(例如從分享等入口進(jìn)來(lái),首個(gè)頁(yè)面是開發(fā)者配置的分享頁(yè)面) |
可以用來(lái)獲取到程序 App 實(shí)例,在各個(gè)端均有實(shí)現(xiàn)
微信小程序端可以傳入一個(gè) Object 參數(shù),格式如下
屬性 | 類型 | 說(shuō)明 | 基礎(chǔ)庫(kù)最低版本 |
---|---|---|---|
allowDefault | Boolean | 在 App 未定義時(shí)返回默認(rèn)實(shí)現(xiàn)。當(dāng)App被調(diào)用時(shí),默認(rèn)實(shí)現(xiàn)中定義的屬性會(huì)被覆蓋合并到App中。一般用于獨(dú)立分包 | 2.2.4 |
入口文件需要包含一個(gè) render
方法,一般返回程序的第一個(gè)頁(yè)面,但值得注意的是不要在入口文件中的 render
方法里寫邏輯及引用其他頁(yè)面、組件,因?yàn)榫幾g時(shí) render
方法的內(nèi)容會(huì)被直接替換掉,你的邏輯代碼不會(huì)起作用。
Taro 項(xiàng)目的頁(yè)面一般都放在 src
中的 pages
目錄下,如果頁(yè)面包含 js
以及 css
,建議頁(yè)面以文件夾的形式進(jìn)行組織,例如 index
頁(yè)面包含 index.js
和 index.scss
,則在 pages
目錄下新建 index
目錄。
頁(yè)面創(chuàng)建好后如果需要渲染展示,則需要在項(xiàng)目入口文件 app.js
中 config
的 pages
數(shù)組中進(jìn)行指定,例如上面提到的 index
頁(yè)面,需要如下進(jìn)行配置,頁(yè)面配置需要指定到頁(yè)面具體的 js
文件,可以不帶 .js
后綴
// ...
class App extends Component {
// 項(xiàng)目配置
config = {
pages: [
'pages/index/index'
]
}
// ...
}
一個(gè)普通的頁(yè)面文件示例如下
import Taro, { Component } from '@tarojs/taro'
import { View, Text } from '@tarojs/components'
import './index.scss'
export default class Index extends Component {
config = {
navigationBarTitleText: '首頁(yè)'
}
componentWillMount () { }
componentDidMount () { }
componentWillUnmount () { }
componentDidShow () { }
componentDidHide () { }
render () {
return (
<View className='index'>
<Text>1</Text>
</View>
)
}
}
Taro 的頁(yè)面同樣是繼承自 Component
組件基類,每一個(gè)頁(yè)面都擁有自己配置 config
,這個(gè)配置是針對(duì)當(dāng)前頁(yè)面配置,配置規(guī)范基于微信小程序的頁(yè)面配置進(jìn)行制定,所有平臺(tái)進(jìn)行統(tǒng)一。
頁(yè)面文件中的 config
配置,在編譯后將生成全局配置文件 app.json
。
頁(yè)面的配置只能設(shè)置 全局配置 中部分 window
配置項(xiàng)的內(nèi)容,頁(yè)面中配置項(xiàng)會(huì)覆蓋 全局配置 的 window 中相同的配置項(xiàng)。
配置示例:
export default class Index extends Component {
config = {
navigationBarBackgroundColor: '#ffffff',
navigationBarTextStyle: 'black',
navigationBarTitleText: '首頁(yè)',
backgroundColor: '#eeeeee',
backgroundTextStyle: 'light'
}
render () {
return (
<View className='index'>
<Text>1</Text>
</View>
)
}
}
屬性 | 類型 | 默認(rèn)值 | 描述 |
---|---|---|---|
navigationBarBackgroundColor | HexColor(十六進(jìn)制顏色值) | #000000 | 導(dǎo)航欄背景顏色,如 #000000 |
navigationBarTextStyle | String | white | 導(dǎo)航欄標(biāo)題顏色,僅支持 black / white |
navigationBarTitleText | String | 導(dǎo)航欄標(biāo)題文字內(nèi)容 | |
navigationStyle | String | default | 導(dǎo)航欄樣式,僅支持以下值:default 默認(rèn)樣式;custom 自定義導(dǎo)航欄,只保留右上角膠囊按鈕 |
backgroundColor | String | 窗口的背景色 | |
backgroundTextStyle | String | dark | 下拉 loading 的樣式,僅支持 dark / light |
backgroundColorTop | String | #ffffff | 頂部窗口的背景色,僅 iOS 支持 |
backgroundColorBottom | String | #ffffff | 底部窗口的背景色,僅 iOS 支持 |
enablePullDownRefresh | boolean | false | 是否開啟當(dāng)前頁(yè)面的下拉刷新。 |
onReachBottomDistance | Number | 50 | 頁(yè)面上拉觸底事件觸發(fā)時(shí)距頁(yè)面底部距離,單位為 px |
pageOrientation | String | portrait | 屏幕旋轉(zhuǎn)設(shè)置,支持 auto / portrait / landscape 詳見 響應(yīng)顯示區(qū)域變化 |
disableScroll | Boolean | false | 設(shè)置為 true 則頁(yè)面整體不能上下滾動(dòng)。 只在頁(yè)面配置中有效,無(wú)法在 app.json 中設(shè)置 |
disableSwipeBack | Boolean | false | 禁止頁(yè)面右滑手勢(shì)返回 |
usingComponents | Object | 否 | 頁(yè)面自定義組件配置 |
各端支持程度如下
屬性 | 微信小程序 | 百度小程序 | 字節(jié)跳動(dòng)小程序 | 支付寶小程序 | H5 | RN |
---|---|---|---|---|---|---|
navigationBarBackgroundColor | ?? | ?? | ?? | ?? | ?? | ?? |
navigationBarTextStyle | ?? | ?? | ?? | ? | ?? | ?? |
navigationBarTitleText | ?? | ?? | ?? | ?? | ?? | ?? |
navigationStyle | ??(微信客戶端 6.6.0) | ??(百度 App 版本 11.1.0) | ?? | ? | ? | ?? |
backgroundColor | ?? | ?? | ?? | ? | ? | ?? |
backgroundTextStyle | ?? | ?? | ?? | ? | ? | ?? |
backgroundColorTop | ??(微信客戶端 6.5.16) | ? | ?? | ? | ? | ? |
backgroundColorBottom | ??(微信客戶端 6.5.16) | ? | ?? | ? | ? | ? |
enablePullDownRefresh | ?? | ?? | ?? | ?? | ? | ? |
onReachBottomDistance | ?? | ?? | ?? | ? | ? | ? |
pageOrientation | ??2.4.0 (auto) / 2.5.0 (landscape) | ? | ? | ? | ? | ? |
disableScroll | ?? | ? | ? | ? | ? | ?? |
disableSwipeBack | ?? | ? | ? | ? | ? | ? |
usingComponents | ?? | ?? | ?? | ?? | ? | ? |
其中,usingComponents
一般不需要配置,只有在需要與引用原生小程序組件的時(shí)候才需要配置。
頁(yè)面的樣式文件建議放在與頁(yè)面 JS 的同級(jí)目錄下,然后通過(guò) ES6 規(guī)范 import
進(jìn)行引入,支持使用 CSS 預(yù)編譯處理器,目前提供了 sass
預(yù)編譯插件 @tarojs/plugin-sass
,需要自行在本地進(jìn)行安裝。
頁(yè)面 JS 要求必須有一個(gè) render
函數(shù),函數(shù)返回 JSX 代碼,具體 JSX 代碼的寫法請(qǐng)參考 JSX 章節(jié)。
由于頁(yè)面 JS 也繼承自 Component
組件基類,所以頁(yè)面同樣擁有生命周期,頁(yè)面的生命周期方法如下:
頁(yè)面加載時(shí)觸發(fā),一個(gè)頁(yè)面只會(huì)調(diào)用一次,此時(shí)頁(yè)面 DOM 尚未準(zhǔn)備好,還不能和視圖層進(jìn)行交互
頁(yè)面初次渲染完成時(shí)觸發(fā),一個(gè)頁(yè)面只會(huì)調(diào)用一次,代表頁(yè)面已經(jīng)準(zhǔn)備妥當(dāng),可以和視圖層進(jìn)行交互
頁(yè)面是否需要更新,返回 false 不繼續(xù)更新,否則繼續(xù)走更新流程
頁(yè)面即將更新
頁(yè)面更新完畢
頁(yè)面卸載時(shí)觸發(fā),如 redirectTo 或 navigateBack 到其他頁(yè)面時(shí)
頁(yè)面顯示/切入前臺(tái)時(shí)觸發(fā)
頁(yè)面隱藏/切入后臺(tái)時(shí)觸發(fā), 如 navigateTo 或底部 tab 切換到其他頁(yè)面,小程序切入后臺(tái)等
在以上所有的生命周期方法中,都可以通過(guò) this.$router.params
獲取打開當(dāng)前頁(yè)面路徑中的參數(shù)。
在小程序中,頁(yè)面還有在一些專屬的事件處理函數(shù),如下
監(jiān)聽用戶下拉刷新事件
監(jiān)聽用戶上拉觸底事件
監(jiān)聽用戶滑動(dòng)頁(yè)面事件
Object 參數(shù)說(shuō)明:
參數(shù) | 類型 | 說(shuō)明 |
---|---|---|
scrollTop | Number | 頁(yè)面在垂直方向已滾動(dòng)的距離(單位px) |
注意:請(qǐng)只在需要的時(shí)候才在 page 中定義此方法,不要定義空方法。以減少不必要的事件派發(fā)對(duì)渲染層-邏輯層通信的影響。注意:請(qǐng)避免在 onPageScroll 中過(guò)于頻繁的執(zhí)行 this.setState() 等引起邏輯層-渲染層通信的操作。尤其是每次傳輸大量數(shù)據(jù),會(huì)影響通信耗時(shí)。
監(jiān)聽用戶點(diǎn)擊頁(yè)面內(nèi)轉(zhuǎn)發(fā)按鈕(Button 組件 openType='share')或右上角菜單“轉(zhuǎn)發(fā)”按鈕的行為,并自定義轉(zhuǎn)發(fā)內(nèi)容。
注意:只有定義了此事件處理函數(shù),右上角菜單才會(huì)顯示“轉(zhuǎn)發(fā)”按鈕
Object 參數(shù)說(shuō)明:
參數(shù) | 類型 | 說(shuō)明 |
---|---|---|
from | String | 轉(zhuǎn)發(fā)事件來(lái)源。 button:頁(yè)面內(nèi)轉(zhuǎn)發(fā)按鈕; menu:右上角轉(zhuǎn)發(fā)菜單 |
target | Object | 如果 from 值是 button ,則 target 是觸發(fā)這次轉(zhuǎn)發(fā)事件的 button ,否則為 undefined |
webViewUrl | String | 頁(yè)面中包含 組件時(shí),返回當(dāng)前 的url |
此事件需要 return 一個(gè) Object,用于自定義轉(zhuǎn)發(fā)內(nèi)容,返回內(nèi)容如下:
自定義轉(zhuǎn)發(fā)內(nèi)容
字段 | 類型 | 說(shuō)明 |
---|---|---|
title | 轉(zhuǎn)發(fā)標(biāo)題 | 當(dāng)前小程序名稱 |
path | 轉(zhuǎn)發(fā)路徑 | 當(dāng)前頁(yè)面 path ,必須是以 / 開頭的完整路徑 |
imageUrl | 自定義圖片路徑,可以是本地文件路徑、代碼包文件路徑或者網(wǎng)絡(luò)圖片路徑。支持 PNG 及 JPG 。顯示圖片長(zhǎng)寬比是 5:4 | 使用默認(rèn)截圖 |
示例代碼
export default class Index extends Component {
config = {
navigationBarTitleText: '首頁(yè)'
}
onShareAppMessage (res) {
if (res.from === 'button') {
// 來(lái)自頁(yè)面內(nèi)轉(zhuǎn)發(fā)按鈕
console.log(res.target)
}
return {
title: '自定義轉(zhuǎn)發(fā)標(biāo)題',
path: '/page/user?id=123'
}
}
render () {
return (
<View className='index'>
<Text>1</Text>
</View>
)
}
}
只有微信小程序支持
基礎(chǔ)庫(kù) 2.4.0 開始支持
小程序屏幕旋轉(zhuǎn)時(shí)觸發(fā)。詳見 響應(yīng)顯示區(qū)域變化
微信小程序中,基礎(chǔ)庫(kù) 1.9.0 開始支持
點(diǎn)擊 tab 時(shí)觸發(fā)
Object 參數(shù)說(shuō)明:
參數(shù) | 類型 | 說(shuō)明 |
---|---|---|
index | String | 被點(diǎn)擊 tabItem 的序號(hào),從 0 開始 |
pagePath | String | 被點(diǎn)擊 tabItem 的頁(yè)面路徑 |
text | String | 被點(diǎn)擊 tabItem 的按鈕文字 |
目前只有微信小程序支持
預(yù)加載鉤子
只有支付寶小程序支持,基礎(chǔ)庫(kù) 1.3.0 開始支持
點(diǎn)擊標(biāo)題觸發(fā)
只有支付寶小程序支持,基礎(chǔ)庫(kù) 1.3.0 開始支持
點(diǎn)擊導(dǎo)航欄額外圖標(biāo)觸發(fā)
只有支付寶小程序支持,基礎(chǔ)庫(kù) 1.11.0 開始支持
暫無(wú)說(shuō)明
只有支付寶小程序支持,基礎(chǔ)庫(kù) 1.3.0 開始支持
下拉截?cái)鄷r(shí)觸發(fā)
H5 暫時(shí)沒(méi)有同步實(shí)現(xiàn)
onReachBottom
、onPageScroll
這兩個(gè)事件函數(shù),可以通過(guò)給 window 綁定 scroll 事件來(lái)進(jìn)行模擬,而onPullDownRefresh
下拉刷新則暫時(shí)只能用ScrollView
組件來(lái)代替了。
頁(yè)面事件函數(shù)各端支持程度如下
方法 | 作用 | 微信小程序 | 百度小程序 | 字節(jié)跳動(dòng)小程序 | 支付寶小程序 | H5 | RN |
---|---|---|---|---|---|---|---|
onPullDownRefresh | 頁(yè)面相關(guān)事件處理函數(shù)--監(jiān)聽用戶下拉動(dòng)作 | ?? | ?? | ?? | ?? | ? | ? |
onReachBottom | 頁(yè)面上拉觸底事件的處理函數(shù) | ?? | ?? | ?? | ?? | ? | ? |
onShareAppMessage | 用戶點(diǎn)擊右上角轉(zhuǎn)發(fā) | ?? | ?? | ?? | ?? | ? | ? |
onPageScroll | 頁(yè)面滾動(dòng)觸發(fā)事件的處理函數(shù) | ?? | ?? | ?? | ?? | ? | ? |
onTabItemTap | 當(dāng)前是 tab 頁(yè)時(shí),點(diǎn)擊 tab 時(shí)觸發(fā) | ?? | ?? | ?? | ?? | ? | ? |
onResize | 頁(yè)面尺寸改變時(shí)觸發(fā),詳見 響應(yīng)顯示區(qū)域變化 | ?? | ? | ? | ? | ? | ? |
componentWillPreload | 預(yù)加載 | ?? | ? | ? | ? | ? | ? |
onTitleClick | 點(diǎn)擊標(biāo)題觸發(fā) | ? | ? | ? | ?? | ? | ? |
onOptionMenuClick | 點(diǎn)擊導(dǎo)航欄額外圖標(biāo)觸發(fā) | ? | ? | ? | ??(基礎(chǔ)庫(kù) 1.3.0) | ? | ? |
onPopMenuClick | ? | ? | ? | ??(基礎(chǔ)庫(kù) 1.3.0) | ? | ? | |
onPullIntercept | 下拉截?cái)鄷r(shí)觸發(fā) | ? | ? | ? | ??(基礎(chǔ)庫(kù) 1.11.0) | ? | ? |
以上成員方法在 Taro 的頁(yè)面中同樣可以使用,書寫同名方法即可,不過(guò)需要注意的,目前暫時(shí)只有小程序端支持(支持程度如上)這些方法,編譯到 H5/RN 端后這些方法均會(huì)失效。
Taro 支持組件化開發(fā),組件代碼可以放在任意位置,不過(guò)建議放在 src
下的 components
目錄中。一個(gè)組件通常包含組件 JS 文件以及組件樣式文件,組織方式與頁(yè)面類似。
一般來(lái)說(shuō),Taro 組件不需要任何配置,但當(dāng)你在 Taro 組件中引用原生小程序組件代碼時(shí),則需要通過(guò)配置 config
來(lái)實(shí)現(xiàn)。
配置項(xiàng)如下
屬性 | 類型 | 必填 | 描述 |
---|---|---|---|
usingComponents | Object | 否 | 組件自定義組件配置 |
usingComponents
中通過(guò) 組件名: 組件相對(duì)路徑
這種 key/value 的方式定義引用的組件。
import Taro, { Component } from '@tarojs/taro'
import { View, Image, Button } from '@tarojs/components'
import './tab.scss'
class Tab extends Component {
onNewTodo = () => {
// dosth
}
componentWillMount () { }
componentDidMount () { }
componentWillUnmount () { }
componentWillReceiveProps () { }
render () {
return (
<View className='tab'>
tab
</View>
)
}
}
組件的樣式文件可以需要在組件中通過(guò) import
語(yǔ)法進(jìn)行引入。
Taro 的組件同樣是繼承自 Component
組件基類,與頁(yè)面類似,組件也必須包含一個(gè) render
函數(shù),返回 JSX 代碼。
由于組件 JS 也繼承自 Component
組件基類,所以頁(yè)面同樣擁有生命周期,頁(yè)面的生命周期方法如下:
組件加載時(shí)觸發(fā),一個(gè)組件只會(huì)調(diào)用一次,此時(shí)組件 DOM 尚未準(zhǔn)備好,還不能和視圖層進(jìn)行交互
組件初次渲染完成時(shí)觸發(fā),一個(gè)組件只會(huì)調(diào)用一次,代表組件已經(jīng)準(zhǔn)備妥當(dāng),可以和視圖層進(jìn)行交互
已經(jīng)裝載的組件接收到新屬性前調(diào)用
組件是否需要更新,返回 false 不繼續(xù)更新,否則繼續(xù)走更新流程
組件即將更新
組件更新完畢
組件卸載時(shí)觸發(fā)
具體生命周期的使用以及組件類的說(shuō)明可以查看組件說(shuō)明章節(jié)。
更多建議: