找回密码
 注册
首页 ≡≡网络技术≡≡ WEB前端 ES6神奇的引入语句 import...from...

框架 ES6神奇的引入语句 import...from...

灰儿 2022-7-27 16:23:57
在uni-app项目中,其中main.js文件里的代码,看得我一头雾水...

  1. import Vue from 'vue';
  2. import App from './App';
  3. import router from './route';
  4. import axios from 'axios';
  5. import './less/index';
复制代码

解释代码之前,先来看我的项目文档(这5行代码位于main.js中):

01.png

那么现在我对上述代码一一作出解释:
  1. import Vue from 'vue';
复制代码

其实最完整的写法是:
  1. import Vue from "../node_modules/vue/dist/vue.js";
复制代码

意思是:
  因为main.js是在src文件中,所以../向前一级相对目录查找node_modules,再依次寻找后面的文件。
如果是Uniapp项目,vue.js文件已内置在 HBuilderX编辑器的目录下,具体为  \update\backup\plugins\uniapp-cli\node_modules\vue\dist\vue.js

下面解释第二条代码:
  1. import App from './App';
复制代码

完整的写法是
  1. import App from './App.vue';
复制代码

顾名思义,这句代码的意思就是引入和main.js同级目录下的App.vue文件。(.vue文件是vue框架的单文件组件。)

下面解释第三条代码:
  1. import router from './route';
复制代码

完整的写法是
  1. import router from './route.js';
复制代码

顾名思义,这句代码的意思就是引入和main.js同级目录下的route.js文件。

下面解释第四条代码:
  1. import axios from 'axios';
复制代码

完整意思是:
  1. import axios from '..\node_modules\axios\dist\axios.js';
复制代码

和引入vue文件是一样的原理,都是从node_modules中加载相应名称的模块。

下面解释第五条代码:
  1. import './less/index';
复制代码

完整意思是:
  1. import './less/index.less';
复制代码

总结:
1.import...from...的from命令后面可以跟很多路径格式,若只给出vue,axios这样的包名,则会自动到node_modules中加载;若给出相对路径及文件前缀,则到指定位置寻找。

2.可以加载各种各样的文件:.js、.vue、.less等等。

可以不输入后缀名既加载是因为这个原因:

webpack解析里的扩展配置:
resolve: {
extensions: ['.wasm', '.js', '.vue', '.json']
}

3.可以省略掉from直接引入。

吐槽:
ES6的import...from...指令挺神奇,不需要指明文件后缀,这样很方便快捷,新手需要一定的耐心去研究,否则是真心看不懂。



灰儿 楼主 2022-8-3 17:42:18
http://www.admin365.cn/thread-46317-1-1.html  ES6中export的三种对外暴露的方式及引入方法
您需要登录后才可以回帖 登录 | 注册
学习中心
站长自定义文字内容,利用碎片时间,随时随地获取优质内容。
Q设计语言 了解更多
Q Design 提供商家设计所需的指导与资源,帮商家快速完成产品设计、降低生产成本。
学习中心
站长自定义文字内容,利用碎片时间,随时随地获取优质内容。
Q设计语言 了解更多
Q Design 提供商家设计所需的指导与资源,帮商家快速完成产品设计、降低生产成本。