ES6神奇的import...from...命令
来源:互联网 发布:get是什么意思网络上的 编辑:程序博客网 时间:2024/05/16 15:52
学习的原因还是起源于大牛github项目的博客源码,看得我一头雾水...
import Vue from 'vue';import App from './App';import router from './route';import axios from 'axios';import './less/index';
于是赶快上了阮一峰大牛的《ES6标准入门》这辆车,学习了:1.项目为什么要模块化?2.ES6模块与CommonJS和AMD模块加载的不同。3.export命令4.import命令5.模块的整体加载
get到很多的新姿势,然而并不能解释import Vue from vue
和其他代码是什么意思。还好,百度到三省吾身丶丶的hexo博客。几句注释就让我柳暗花明。
解释代码之前,先来看我的项目文档(这5行代码位于main.js中):
那么现在我对上述代码一一作出解释:
import Vue from 'vue';
其实最完整的写法是:
import Vue from "../node_modules/vue/dist/vue.js";
意思是:
因为main.js是在src文件中,所以../向前一级相对目录查找node_modules,再依次寻找后面的文件。
文件找到了,那么文件内是否存在Vue呢?
事实证明,Vue是存在于vue.js中的。
下面解释第二条代码:
import App from './App';
完整的写法是
import App from './App.vue';
顾名思义,这句代码的意思就是引入我们写好的App.vue文件。(.vue文件是vue框架的单文件组件。)
下面解释第三条代码:
import router from './route';
完整的写法是
import router from './route.js';
顾名思义,这句代码的意思就是引入和main.js同级目录下的route.js文件。
下面解释第四条代码:
import axios from 'axios';
完整意思是:
import axios from '..\node_modules\axios\dist\axios.js';
和引入vue文件是一样的原理,都是从node_modules中加载相应名称的模块。
事实证明,axios.js文件中存在axios。
下面解释第五条代码:
import './less/index';
完整意思是:
import './less/index.less';
查找成功:
个人总结:
1.import...from...的from命令后面可以跟很多路径格式,若只给出vue,axios这样的包名,则会自动到node_modules中加载;若给出相对路径及文件前缀,则到指定位置寻找。
2.可以加载各种各样的文件:.js、.vue、.less等等。
3.可以省略掉from直接引入。
吐槽:
ES6的import...from...指令挺神奇,不需要指明文件后缀,这样很方便快捷,新手需要一定的耐心去研究,否则是真心看不懂。
作者:趁你还年轻233
链接:http://www.jianshu.com/p/c0be35475e54
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
- ES6神奇的import...from...命令
- 【ES6】const命令和import命令
- ECMAScript 2015(ES6):import和export命令
- from * import 的实质
- from module import 和 import 的区别
- python import与from...import....的区别
- from module import 和 import 的区别
- import和from...import的使用
- from import 与 import 的区别
- java 神奇的import之静态导入
- ES6 export & import的基本用法
- Python中import, from...import,import...as的区别
- from....import 导入的总结
- python 的 from . import module
- ES6的const命令
- svn的import命令
- from import
- import 和 from...import
- nifi探索之JSON文件写入数据库
- 51Nod 1284 2 3 5 7的倍数
- 软件工程师
- 关于FTP远程和服务器通信建立连接、增加、删除、下载、预览图片功能
- C++文件操作——按行读取txt文本文件
- ES6神奇的import...from...命令
- android创建目录不成功
- multiset
- PAT-AL 1013. Battle Over Cities
- 第五节:SpringBoot的数据库CRUD
- 生产库,查询库和测试库的区别
- 基于深度学习的视频检测(一)
- DAN —— 人脸关键点
- Android 显示输入法中的emoji表情以及String字符串转码