为何会忽然用到webpack这个管理特性呢?vue
项目某个页面须要引入N张demo图片。即资源的批量引入:若是要引入10+个以上的图片资源,就须要写10+个以下的引入代码:import XXX from 'relative/path/assets/imgs/xxx';
,那若是再多一点的静态资源须要引入呢?这时候require.context就派上了用场。webpack
官方文档的介绍先放在这里,可小觑一下,了解使用姿式。web
话很少说,针对上面的场景,咱们上一下代码吧。vuex
场景须要咱们引入某个指定文件夹下的全部webp格式的图片,在单击demo1的时候展现demo1下的x张案例图,在单击demoX的时候展现demoX下的x张案例图。浏览器
// 经过require.context的方式引入指定的路径下匹配到的模块引用 const demoImgsContext = require.context('@src/assets/imgs/demo', false, /\.webp$/); ... // 使用姿式 trigger(type) { this.demoImgs = Arry.from({length: config.type}, (key, value) => value + 1) .map(index => demoImgsContext(`./${type}_demo${index}.webp`)); }
触类旁通的场景还有须要的么?
好比vuex引入多个module的store。也可使用这个方法。ide
// 添加module文件是,文件命请按照module_XXX的方式命名 // 自动引入module文件夹下的js文件 const mutationContext = require.context('./module', false, /.*\.js/); const modules = mutationContext.keys().reduce((prev, cur) => { // 排除module_root文件 const matches = cur.match(/module_(?!.*root)(\w+)\.js/); const key = matches && matches[1]; key && (prev[key] = mutationContext(cur).default); return prev; }, {});
看下打包后的dist目录下,咱们的静态图片案例chunk这个部分的代码是啥样的。ui
trigger方法中引用模块资源的代码以下,对y方法进行调用,传入了一个资源的路径。this
map(function (e) { return y("./".concat(t, "_demo").concat(e, ".webp")) })
那y方法是什么呢?顺藤摸瓜,继续看下打包后的代码。code
y = a("ae36");
y方法是某个模块的export,继续查看这个id下的模块代码:图片
ae36: function (t, e, a) { // 此处是一个map映射,key值和真正的资源id的映射 var i = { "./a_module_demo1.webp": "6085", "./a_module_demo2.webp": "fd3b", "./b_module_demo1.webp": "cbf6", "./b_module_demo2.webp": "220e", "./c_module_demo1.webp": "273e", "./c_module_demo2.webp": "5a5e", "./d_module_demo1.webp": "75b0", "./d_module_demo2.webp": "2d3e" }; // 此处根据module的id值,真正require一个资源 function r(t) { var e = o(t); return a(e) } function o(t) { var e = i[t]; if (!(e + 1)) { var a = new Error("Cannot find module '" + t + "'"); throw a.code = "MODULE_NOT_FOUND", a } return e } r.keys = function () { return Object.keys(i) }, r.resolve = o, t.exports = r, r.id = "ae36" },
"6085","fd3b"等map映射的value值可想而知,是真正的资源id值,其对应的模块映射以下:
6085: function (t, e) { t.exports = "//${你配置的项目publicPath}/img/1_module_demo1.ed6db768.webp" },
当用户触发trigger方法时,根据type和index指定的值,require.context存储的模块资源引用会根据key值找到真正的资源模块,进行require,浏览器会帮助咱们下载相应的资源,作到了批量引入后按需加载的想法。
手痒的同窗能够磨刀霍霍试试了~