码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • vue3中使用vue-i18n(ts中使用$t, vue3不用this)


    vue项目里多语言工具一直用的vue-i18n。
    以前用的 vue2,也没啥大问题,就是配置好之后用t(“你的属性名”)就行,现在用vue3其实本来也没太大变化。
    但是配置完之后,在html中用$t()没有问题,显示文案什么的一切正常。而在ts中使用$t()方法报错,后来才发现是我没有设置全局的$t()方法。

    在这里插入图片描述
    记录一下在vue3中使用vue-i18n的方法:

    1. 安装vue-18n
    2. 配置
    3. 应用
    4. 挂载全局方法$t以方便在ts中使用(本次记录的重点)

    由于1.2.3.好多人写过了,我就简单的写一下,本次记录的重点是4,因为我发现网上好多博客都只写了$t在html中的使用,但是大都没提到在ts中也可能用到。

    1. 安装
    npm install vue-i18n@next 或 yarn add vue-i18n@next
    
    1. 在 src 目录下新建 lang 并新建 index.ts 文件
    import App from '@/App.vue'
    import { createApp } from 'vue'
    import { createI18n } from 'vue-i18n'
    import enLocale from './en/index';
    import zhLocale from './zh/index';
    
    const messages = {
        zh: zhLocale,
        cn: zhLocale,
        en: enLocale,
        us: enLocale,
        
    }
    
    const localLang = navigator.language.split('-')[0];
    const storageLang = window.localStorage.getItem('locale')?.split('"')[1].split('"')[0].toLocaleLowerCase() || 'en';
    const c = (storageLang.toLocaleLowerCase() !== 'zh' && storageLang.toLocaleLowerCase() !== 'en') ? 'en' : storageLang;
    
    const i18n = createI18n({
        globalInjection: true, //全局生效$t
        locale: c || localLang || 'en',
        messages,
        legacy: false,
    })
    
    const app = createApp(App)
    app.use(i18n)
    

    在这里插入图片描述

    上图中两个语言包的index.ts中的内容自己根据语言需要写:

    export default {
        nNation: 'Country/Region',
        pleaseInput: 'Account',
    
    }
    
    1. 在ts中使用全局方法$t
    import { getCurrentInstance } from "vue";
    const { appContext : { config: { globalProperties } } } = getCurrentInstance();  // 这里可以根据需要写个hook
    console.log(globalProperties.$t('pleaseSelectNation'))
    

    在html中的使用就比较正常了:

    {{ $t("nation") }}
    

    其实本文算是新手记录一下对于globalProperties的使用,希望对您有所帮助。

  • 相关阅读:
    超轻巧的电竞鼠标,手感不错反应精准,雷柏VT9Pro体验
    动量轮动与光大RSRS指标在backtrader的实现
    Qt监控目录文件变化:QFileSystemWatcher用法
    Python 的四舍五入的两个方法,你学会了吗?
    别走,这里有一份摸鱼小妙招,别人我不告诉他!
    SpringCloud基础概念学习笔记(Eureka、Ribbon、Feign、Zuul)
    用DIV+CSS技术设计的体育篮球主题 校园体育网页与实现制作(web前端网页制作课作业)
    史上最全电商API接口(数据参数返回值说明)
    Java --- Mybatis的动态sql标签
    java-php-python-ssm网上商城系统计算机毕业设计
  • 原文地址:https://blog.csdn.net/JaneLittle/article/details/127112273
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号