继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

页面初始化调用configuration.setLocale()接口踩坑记录

华为开发者论坛
关注TA
已关注
手记 196
粉丝 12
获赞 3

问题描述

快应用app.ux中定义了全局方法changeLocaleConfiguration,该方法是用于设置应用显示语言,在首页生命周期onInit中调用changeLocaleConfiguration(),实际已经触发了该方法,但是应用语言并未发生改变。 代码如下:

app.ux中:

   changeLocaleConfiguration() {
      this.localeObject = configuration.getLocale()
      if (this.localeObject.language === 'zh') {
        configuration.setLocale({
          language: 'en',
          countryOrRegion: 'US'
        })
      }
      else {
        configuration.setLocale({
          language: 'zh',
          countryOrRegion: 'CN'
        })
      }
    }

首页:

 onInit() {
      this.$app.$def.changeLocaleConfiguration()
    }

问题分析

页面初始化onInit()时间非常短,设置语言属于比较耗时的操作,页面来不及渲染。

解决办法

在页面初始化调用设置语言接口时候加上时延,代码如下:

onInit() {
      setTimeout(() => {
        this.$app.$def.changeLocaleConfiguration()
      }, 100);
    }

总结:

不建议在页面onInit中调用耗时的操作,如果必须要用需要加上时延。

作者:鼓楼赵又廷

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP