网站首页 > 技术文章 正文
vue2中想动态引入资源,而且涉及到if else 的判断条件的 ,类似于vue/index.js 中的
if (process.env.NODE_ENV === 'production') {
module.exports = require('./dist/vue.cjs.prod.js')
} else {
module.exports = require('./dist/vue.cjs.js')
}
而这个require是内部封装。我们项目中又不是直接引用。 而且用 import 又不能用到if else 的局部中
采用 import.meta.globEager 方法代替require导入资源。比如下面根据的引入mockjs ,可以把这段放在main.js中
// 非生产环境, 适配mockjs模拟数据 // api: https://github.com/nuysoft/Mock
if (process.env.NODE_ENV !== 'production') {
//debugger
const allmockfiles= import.meta.globEager( '@/api/allmock.js')
}
而不是要引用某个目录下的文件的话,比如我下面的中英文
//提示信息仅供在开发环境生效
import { createI18n } from 'vue-i18n';
import store from '@/store'
const files= import.meta.globEager( './modules/*.js')
let messages ={}
Object.keys(files).forEach((c )=> {
const module = files[c].default
const moduleName =c.replace( /^\.\/(.*)\/(.*)\.\w+$/, '$2')
messages[moduleName] = module
})
//const lang = store.state.app.lang || navigator.userLanguage || navigator.language // 初次进入,采用测览器当前设置的语言,然认采用中文
const lang = navigator.userLanguage || navigator.language
const locale = lang.indexOf('en')!== -1 ? 'en':'zh-cn'
const i18n = createI18n({
legacy: false,
__VUE_I18N_LEGACY_API__: false,
__VUE_I18N_FULL_INSTALL__: false,
locale: locale,
fallbackLocale:'zh-cn',
messages
})
document.querySelector( 'html' ).setAttribute( 'lang', locale)
export default i18n
其中用到的加载的部分核心就是,要的人也可以在forEach方法里面自己加判断条件
const files= import.meta.globEager( './modules/*.js')
let messages ={}
Object.keys(files).forEach((c )=> {
const module = files[c].default
const moduleName =c.replace( /^\.\/(.*)\/(.*)\.\w+$/, '$2')
messages[moduleName] = module
})
猜你喜欢
- 2025-05-24 ROS2 Jazzy:用C++实现一个动作服务器和客户端
- 2025-05-24 高性能Gin框架原理学习教程
- 2025-05-24 Python 3.8异步并发编程指南
- 2025-05-24 聊聊redisson的RLock的unlock
- 2025-05-24 Linux分区页框分配器之水位
- 2025-05-24 记一次集群内无可用http服务问题排查
- 2025-05-24 案例 | 某电商如何构建Zabbix高可用监控平台?
- 2025-05-24 Fluent 重叠网格和动态网格 教程
- 2025-05-24 性能测试工具Locust
- 2025-05-24 iLogtail 使用入门 - K8S 环境日志采集到 SLS
- 05-24高中数学解题分析方法及知识点
- 05-24C/C++编程笔记:无法在C++中重载的函数,六种方式
- 05-24面试与实战:什么是 Lambda?该如何使用?
- 05-24设计模式之单件模式
- 05-24Axon Framework - 模型- 聚合
- 05-24自动化利器Python类实例方法、静态方法和类方法的区别和用法
- 05-24嵌入式开发必看!面向过程VS面向对象,哪种更适合你的项目?
- 05-24Python:深度剖析实例方法、类方法和静态方法的区别
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)