多个文件 import 的相同模块里的对象

多个文件 import 的相同模块里的对象,是否永远都是同一个对象?

在store的index.js中

import vue from 'vue'

import Vuex from 'vuex'

并配置有关对象

然后再app.vue中配置vm

在不同的文件中 import一个vue对象,在任何情况下,所有的文件是否得到的都为同一个对象,也就是单例的?对vue的修改配置是否都在同一个上

在学习vue中,想到这个问题,因为没有es6,webpack等基础就直接学,有些疑惑,在网上搜索了一下

得到如下解答:

可以确定node和webpack实现的模块都是单例,

无论是NodeJS和Webpack,默认的资源Index都是文件的绝对路径。

所以只要绝对路径相同,文件就应该是只被加载一次,第二次加载就是从cache中获取

第一次加载的时候,会执行你的代码,并且获取该Module Export的内容。

然后,把获取到的内容直接放入Module Cache。

这样,在下次加载的时候,就不会再执行你的JS,而是直接返回Module Cache中的代码,而非再执行一遍你的代码。

因为不会再执行一遍,你得到的永远是同一个对象。

测试:在两个不同的Module里面require它。然后输出看看是不是同一个时间。

导入两者

moudule1

moudule2

输出:

结果:

相关推荐
神州数码云基地1 分钟前
首次开发陌生技术?用 AI 赋能前端提速开发!
前端·人工智能·开源·ai开发
程序员小易18 分钟前
前端轮子(2)--diy响应数据
前端·javascript·浏览器
前天的五花肉19 分钟前
D3.js研发Biplot(代谢)图
前端·javascript·css
董世昌4122 分钟前
JavaScript 中 undefined 和 not defined 的区别
java·服务器·javascript
oh,huoyuyan25 分钟前
【实用技巧】火语言RPA:界面『日期时间』控件,实现网页日期自动填写
前端·javascript·rpa
程序员小寒25 分钟前
前端性能优化之Webpack篇
前端·webpack·性能优化
谢尔登25 分钟前
React的Fiber架构
前端·react.js·架构
我是华为OD~HR~栗栗呀28 分钟前
(华为od)21届-Python面经
java·前端·c++·python·华为od·华为·面试
刘一说40 分钟前
ES6+核心特性全面浅析
java·前端·es6
i_am_a_div_日积月累_43 分钟前
el-tree半选回显问题;el-tree获取半选节点id
javascript·vue.js·elementui