zoukankan      html  css  js  c++  java
  • 多个文件 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

    输出:

    结果:

  • 相关阅读:
    Tomcat 三种运行方式
    MariaDB介绍
    Nginx 平滑升级
    代理命令 proxy_pass 详解
    Nginx 和 Tomcat 负载均衡
    基于Apache和tomcat实现负载均衡
    centos7 通过源码编译的方式安装和配置Apache
    基于nginx结合openssl实现https
    HTTP 和 HTTPS 区别
    linux系统中修改别名配置文件,构建命令别名
  • 原文地址:https://www.cnblogs.com/zhukaile/p/15792040.html
Copyright © 2011-2022 走看看