vue项目引入json/js文件批量或单个方法

vue项目

json

javascript 复制代码
// 方式一 : 将文件内容完整的引入
import json from './src/assets/xxx.json'
console.log(json)
console.log('---')

// 方式二 : 部分引入-名称必须是文件中定义的key
import {name1,name2} from './src/assets/xxx.json'
console.log(name1)
console.log(name2)

js

javascript 复制代码
import '../xxxxx.js';
批量引入
javascript 复制代码
//三级边框
let lnglatJson = loadFrames (require.context('../assets/js/lnglatJson', false, /\.js$/))

/**
 * 批量加载js
 * @param {Function} context - require.context 创建的函数
 * @returns {Array<string>} 返回的所有js
 */
function loadFrames (context) {
  const frames = {}
  context.keys().forEach(k => {
    if(k.includes('anyang')){
      frames['xx']=context(k)
    }else if(k.includes('hebi')){
      frames['xx']=context(k)
    }else if(k.includes('xinxiang')){
      frames['xxx']=context(k)
    }
  })
  return frames
}
export default {lnglatJson}

vite项目

json

javascript 复制代码
//单个
import.meta.glob('./languages/**/*.json', {
    import: 'default',
    eager: true,
  })
javascript 复制代码
//json导入
//批量
(async function(){
  let jsonFiles =await import.meta.globEager('../../../../public/js/map/json/*.json');
  console.log(jsonFiles)
  let jsonData={}
  for (let filePath in jsonFiles) {
    const fileData = jsonFiles[filePath].default;
    jsonData[filePath.replace(/.*\//, '')] = fileData; // 移除路径前缀
  }
  console.log(jsonData)
})()
//写在函数中
onMounted(async () => {
   let jsonFiles =await import.meta.globEager('../../../../public/js/map/json/*.json');
  console.log(jsonFiles)
  let jsonData={}
  for (let filePath in jsonFiles) {
    const fileData = jsonFiles[filePath].default;
    jsonData[filePath.replace(/.*\//, '')] = fileData; // 移除路径前缀
  }
  console.log(jsonData)
});

js

javascript 复制代码
//js导入
import '../../../../public/js/map/yunnan.js';
//云南导入
const files = import.meta.globEager("../../../../public/js/map/yunnan/*")
let AllPics = Object.values(files).map((v) => v.default);
相关推荐
小胖霞8 分钟前
node全栈系列(七)-增加验证码登录
前端·vue.js·node.js
董世昌419 分钟前
箭头函数和普通函数有什么区别
开发语言·javascript·ecmascript
A242073493037 分钟前
js流程控制语句
开发语言·前端·javascript
yngsqq41 分钟前
二维异形排版、二维装箱(NPF碰撞检测)——CAD c#二次开发
开发语言·javascript·c#
AAA阿giao1 小时前
JavaScript 执行机制深度解析:从 V8 引擎到作用域链、变量提升与闭包的全面剖析
前端·javascript·面试
软件技术NINI1 小时前
html css js网页制作成品——陈都灵html+css 5页附源码
javascript·css·html
询问QQ:276998851 小时前
基于Skyhook和地棚控制的半主动悬架模型——详细解读1/4车辆平顺性评价指标及MATLAB...
vue.js
ohyeah1 小时前
用原生 JS 手写一个“就地编辑”组件:EditInPlace 的 OOP 实践
前端·javascript
毕设源码-邱学长1 小时前
【开题答辩全过程】以 基于JavaScript的图书销售网站为例,包含答辩的问题和答案
开发语言·javascript·ecmascript
重铸码农荣光1 小时前
深入理解 JavaScript 中的 this:一场关于作用域、调用方式与设计哲学的思辨
前端·javascript