在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它。然后输出看看是不是同一个时间。
![](https://img2020.cnblogs.com/blog/2090323/202201/2090323-20220112121610994-398104557.png)
导入两者
moudule1
![](https://img2020.cnblogs.com/blog/2090323/202201/2090323-20220112121625136-213000574.png)
moudule2
![](https://img2020.cnblogs.com/blog/2090323/202201/2090323-20220112121531535-1924507540.png)
输出:
![](https://img2020.cnblogs.com/blog/2090323/202201/2090323-20220112121516894-1413297156.png)
结果:
![](https://img2020.cnblogs.com/blog/2090323/202201/2090323-20220112121655399-647185762.png)