切换到使用 wo.pagesJson

This commit is contained in:
陆柯 2022-04-01 19:41:35 +08:00
parent 5a639958f3
commit cbea8a6d0c

View File

@ -55,11 +55,12 @@ export default {
},
localizeText(i18nText) {
const pageNow = this?.$store ? this // 对于组件内定义的 i18nText要使用 this 来获得组建内的 i18nText而不是 getCurrentPages[...] 去访问全局页面的 i18nText。
: getCurrentPages()[getCurrentPages().length - 1] // 如果直接挂载到 Vue.prototype 下,那么可以直接访问 this.i18nText。但如果通过 this.$T.localeText 访问,那么 this.i18nText 就报错了。因此安全起见,先获取当前 page
i18nText = i18nText || pageNow.i18nText // 解析输入参数 i18nText或者 pageNow.i18nText
if (i18nText && typeof(i18nText)==='object' && pageNow.$store?.state?.i18n?.mylang) {
return i18nText[pageNow.$store.state.i18n.mylang] || ''
const mylang = getApp().$store.state.i18n.mylang // pageNow 有可能不存在,所以用 getApp().$store 更安全
const pageNow = this.$store ? this // 对于组件内定义的 i18nText要使用 this 来获得组建内的 i18nText而不是 getCurrentPages[...] 去访问全局页面的 i18nText。
: getCurrentPages()[getCurrentPages().length - 1] // [20220401] 发现在 topWindow 里, 获取的 pageNow 是空的。因此在 topWindow 里不要使用 i18nText 字段。
i18nText = i18nText || pageNow?.i18nText // 如果本方法直接挂载到 Vue.prototype 下,那么可以直接访问 this.i18nText。但如果挂载到 wo 下,那么 this.i18nText 就报错了。因此安全起见,通过 pageNow.i18nText 访问。
if (i18nText && typeof (i18nText) === 'object' && mylang) {
return i18nText[mylang] || ''
}
if (typeof i18nText === 'string') {
return i18nText
@ -70,13 +71,13 @@ export default {
localeText() {
const pageNow = this?.$store ? this // 对于组件内定义的 i18nText要使用 this 来获得组件内的 i18nText而不是 getCurrentPages[...] 去访问全局页面的 i18nText。
: getCurrentPages()[getCurrentPages().length - 1]
return pageNow.i18nText?.[pageNow.$store.state.i18n.mylang] || {}
return pageNow?.i18nText?.[getApp().$store.state.i18n.mylang] || {}
},
setBarTitles ({ windowTitle, pageTitle } = {}) {
const pageNow = getCurrentPages()[getCurrentPages().length - 1]
const mylang = getApp().$store.state.i18n.mylang
const pagesJson = getApp().$pagesJson
const pagesJson = getApp().wo.pagesJson
const pageNow = getCurrentPages()[getCurrentPages().length - 1]
// #ifdef H5
document.title = windowTitle || pagesJson?.appInfo?.i18nText?.[mylang] // 必须放在 setNavigationBarTitle 之后,否则会被其覆盖掉。
@ -85,8 +86,8 @@ export default {
uni.setNavigationBarTitle({
title:
pageTitle ||
pageNow.i18nText?.[mylang]?.tPageTitle || // 页面.vue 的 i18nText 对象
pageNow.i18nPageTitle?.[mylang] || // 页面.vue 的 i18nPageTitle 变量
pageNow?.i18nText?.[mylang]?.tPageTitle || // 页面.vue 的 i18nText 对象
pageNow?.i18nPageTitle?.[mylang] || // 页面.vue 的 i18nPageTitle 变量
pagesJson?.pages?.find((page) => page.path === pageNow.route)?.i18nPageTitle?.[mylang], // pages.json 的页面配置里
})