浅谈vue路径优化之resolve


Posted in Javascript onOctober 13, 2017

通过vue-cli来创建vue+webpack的项目时,已经有很多都配置好了,但是路径方面为了方便开发,还可以优化。

1. resolve.extensions

在webpack.base.conf.js中,我们可以看到resolve配置,其中的extengsions是一个数组,如下所示:

extensions: ['.js', '.vue', '.json'],

通过这样的配置,我们在组件中过着路由中应用组件时,就可以更为方便的应用,比如:

import Hello from '@components/Hello';

即Hello.vue这个组件我们不需要添加.vue后缀就可以引用到了,如果不用extensions, 我们就必须要用@components/Hello.vue来引入这个文件。

2. resolve.alias

在组件之间相互引用时,可能是下面这样的:

import Hello from '../src.components/Hello';

其中的路径是相对于当前页面的。 但是如果嵌套等更为复杂,那么写起来会比较麻烦。但是如果我们通过这样的配置:

resolve: {
  extensions: ['.js', '.vue', '.json'],
  alias: {
   'vue$': 'vue/dist/vue.esm.js',
   '@pages': path.join(__dirname, "..", "src", "pages"),
   "@components": path.join(__dirname, "..", "src", "components"),
   // 注意: 静态资源通过src,不能这么设置。
   // "@assets": path.join(__dirname, "..", "src", "assets"),
  }

其中vue$表示引入vue,就可以像下面这么写:

import Vue from 'vue'

另外,对于@pages和@components我们就可以直接引用了,而省去了一大堆的复杂应用,另外通过@可以消除歧义。如下所示:

import Hello from '@components/Hello';
import App from '@pages/App'

值得注意的时: 在webpack.config.js中我们不能使用../ 以及./这种形式的路径方式,而是通过 path.join 和 __dirname 这种形式来表示路径,否则会报错。

另外: 在组件中,我们会引用一些静态文件,即static下的文件, 这时我们就不能用 alias 下的配置了,而必须使用一般的配置方式。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Mootools 1.2教程 Tooltips
Sep 15 Javascript
utf-8编码引起js输出中文乱码的解决办法
Jun 23 Javascript
查找Oracle高消耗语句的方法
Mar 22 Javascript
node中socket.io的事件使用详解
Dec 15 Javascript
jquery插件qrcode在线生成二维码
Apr 26 Javascript
JavaScript中判断数据类型的方法总结
May 24 Javascript
JS重载实现方法分析
Dec 16 Javascript
jQuery实现菜单栏导航效果
Aug 15 jQuery
react-native组件中NavigatorIOS和ListView结合使用的方法
Sep 30 Javascript
基于rollup的组件库打包体积优化小结
Jun 18 Javascript
详解实现一个通用的“划词高亮”在线笔记功能
Apr 23 Javascript
使用 Github Actions 自动部署 Angular 应用到 Github Pages的方法
Jul 20 Javascript
薪资那么高的Web前端必看书单
Oct 13 #Javascript
vue router demo详解
Oct 13 #Javascript
JS实现的简单表单验证功能示例
Oct 13 #Javascript
javascript基于定时器实现进度条功能实例
Oct 13 #Javascript
layui中layer前端组件实现图片显示功能的方法分析
Oct 13 #Javascript
详解如何去除vue项目中的#——History模式
Oct 13 #Javascript
原生JS上传大文件显示进度条 php上传文件代码
Mar 27 #Javascript
You might like
php学习笔记之 函数声明
2011/06/09 PHP
从零开始学YII2框架(二)通过 Composer 安装扩展插件
2014/08/20 PHP
php mysql like 实现多关键词搜索的方法
2016/10/29 PHP
使用PHP连接数据库_实现用户数据的增删改查的整体操作示例
2017/09/01 PHP
深入理解javascript构造函数和原型对象
2014/09/23 Javascript
jquery实现平滑的二级下拉菜单效果
2015/08/26 Javascript
jQuery EasyUI Draggable拖动组件
2017/03/01 Javascript
swiper动态改变滑动内容的实现方法
2018/01/17 Javascript
解决vue.js this.$router.push无效的问题
2018/09/03 Javascript
vue-cli项目代理proxyTable配置exclude的方法
2018/09/20 Javascript
一百行JS代码实现一个校验工具
2019/04/30 Javascript
JavaScript封闭函数及常用内置对象示例
2019/05/13 Javascript
js消除图片小游戏代码
2019/12/11 Javascript
JavaScript中的类型检查
2020/02/03 Javascript
vue+elementUI实现简单日历功能
2020/09/24 Javascript
pyqt4教程之实现windows窗口小示例分享
2014/03/07 Python
python操作mongodb根据_id查询数据的实现方法
2015/05/20 Python
python 网络编程详解及简单实例
2017/04/25 Python
pandas将DataFrame的列变成行索引的方法
2018/04/10 Python
Python机器学习k-近邻算法(K Nearest Neighbor)实例详解
2018/06/25 Python
python实现文本界面网络聊天室
2018/12/12 Python
Flask之请求钩子的实现
2018/12/23 Python
python之验证码生成(gvcode与captcha)
2019/01/02 Python
解决新版Pycharm中Matplotlib图像不在弹出独立的显示窗口问题
2019/01/15 Python
Python安装selenium包详细过程
2019/07/23 Python
python Pillow图像处理方法汇总
2019/10/16 Python
python tornado修改log输出方式
2019/11/18 Python
Python插入Elasticsearch操作方法解析
2020/01/19 Python
使用python接受tgam的脑波数据实例
2020/04/09 Python
Python编写单元测试代码实例
2020/09/10 Python
CSS3+DIV实现漂亮的动画彩色标签
2016/06/16 HTML / CSS
使用 HTML5 Canvas 制作水波纹效果点击图片就会触发
2014/09/15 HTML / CSS
美国豪华时尚女性精品店:Kirna Zabête
2018/01/11 全球购物
毕业生自荐材料范文
2014/12/30 职场文书
学校光盘行动倡议书
2015/04/28 职场文书
党内外群众意见范文
2015/06/02 职场文书