ES6神奇的import...from...命令

6 篇文章 0 订阅
6 篇文章 0 订阅

学习的原因还是起源于大牛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
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 10
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Node.js中,您可以使用require语句来导入模块,而不是使用import语句。这是因为Node.js使用的是CommonJS模块系统,而不是ES6模块系统。 如果您想在Node.js中使用ES6模块系统,您可以使用Babel或TypeScript等工具进行转换。在Babel中,您可以使用@babel/plugin-transform-modules-commonjs插件来将ES6模块转换为CommonJS模块。在TypeScript中,您可以将模块设置为“commonjs”选项。 以下是一个使用Babel的示例: 1. 安装Babel和插件 使用npm安装Babel和@babel/plugin-transform-modules-commonjs插件: ``` npm install --save-dev @babel/core @babel/cli @babel/plugin-transform-modules-commonjs ``` 2. 创建Babel配置文件 在项目根目录下创建一个.babelrc文件,并添加以下配置: ``` { "presets": ["@babel/preset-env"], "plugins": ["@babel/plugin-transform-modules-commonjs"] } ``` 3. 转换代码 使用Babel CLI命令来转换代码: ``` npx babel src --out-dir dist ``` 这将把src目录中的所有文件转换为dist目录中的CommonJS模块。 4. 导入模块 在您的代码中,您现在可以使用import语句来导入转换后的CommonJS模块: ``` import { foo } from './my-module'; ``` 注意:使用import语句需要在Node.js中启用ES6模块,您可以在启动Node.js应用程序时使用--experimental-modules选项。例如: ``` node --experimental-modules app.js ``` 或者,您可以将"type": "module"添加到您的package.json文件中,以启用ES6模块: ``` { "name": "my-app", "type": "module", "main": "index.js" } ``` 这样,您就可以使用import语句来导入模块,而无需使用Babel或TypeScript进行转换。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值