多个文件 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

输出:

结果:

相关推荐
鹏多多16 小时前
vue3监听属性watch和watchEffect的详解
前端·javascript·vue.js
ruanCat16 小时前
使用 cloudflare worker 实现域名重定向
前端
华仔啊16 小时前
关于移动端100vh的坑和终极解决方案,看这一篇就够了!
前端·css
Hashan16 小时前
Webpack 核心双引擎:Loader 与 Plugin 详解
前端·webpack
前端端16 小时前
claude code 学习记录
前端
一位搞嵌入式的 genius16 小时前
ES6 核心特性详解:从变量声明到函数参数优化
前端·笔记·学习
JarvanMo16 小时前
Flutter:纯函数与不可变模型
前端
玲小珑16 小时前
LangChain.js 完全开发手册(六)Vector 向量化技术与语义搜索
前端·langchain·ai编程
晓得迷路了17 小时前
栗子前端技术周刊第 97 期 - Viteland:8 月回顾、Redux Toolkit 2.9、Nuxt 4.1...
前端·javascript·nuxt.js
前端双越老师17 小时前
前端开发 AI Agent 智能体,需要掌握哪些知识?
前端·node.js·agent