为了账号安全,请及时绑定邮箱和手机立即绑定

vue-cli中 'vue$'配置的别名问题

vue-cli中 'vue$'配置的别名问题

红颜莎娜 2019-02-12 23:05:40
在脚手架当中我们总能看到 'vue$'配置了别名'vue/dist/vue.esm.js'alias: {  'vue$': 'vue/dist/vue.esm.js',  '@': resolve('src')}module: {rules: [   ...(config.dev.useEslint ? [createLintingRule()] : []),   {    test: /\.vue$/,    loader: 'vue-loader',    options: vueLoaderConfig   }]}但是我们实际引用vue的时候都是 import Vue from 'vue'并没有走这个别名而vue的npm包中的package.json 中 "main": "dist/vue.runtime.common.js", 默认是走vue.runtime.common.js所以问题来了 alias 中的 'vue$': 'vue/dist/vue.esm.js', 作用是什么呢???
查看完整描述

1 回答

?
慕哥9229398

TA贡献1877条经验 获得超6个赞

resolve-alias
这个是 webpack.rosolve.alias 的文档, vue$后面的 $代表精确匹配

运行时 + 编译器 vs. 只包含运行时
这个 vue 文档, 是为什么要写 'vue$': 'vue/dist/vue.esm.js',需要完整的含 编译器 的 vue 版本时才写

但是我们实际引用vue的时候都是 import Vue from 'vue'并没有走这个别名

这个只要配置 aliaswebpack 在寻找依赖的时候会判断 是否别名,肯定会走 vue$ 的

module.rulestest: /\.vue$/,这个 $ 是正则的 $,跟 alias 的 $ 不是一回事


查看完整回答
反对 回复 2019-02-12
  • 1 回答
  • 0 关注
  • 521 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信