zoukankan      html  css  js  c++  java
  • JS中的「import」和「require 」

    importrequire 是JS模块化编程使用的,是前端开发者们在性能探索中的又一大进步。

    $ 对模块化的理解

      模块化是一种将系统分离成独立功能部分的方法,一个模块是为完成一个功能的一段程序或子程序。"模块"是系统中功能单一可替换的部分。
      模块化思想是从java上衍生过来的,他将所需要的功能封装成一个类,哪里需要就在哪里调用,JS中没有类的说法,但它引入了这种思想,在js中用对象或构造函数来模拟类的封装实现模块化,而在html上,则使用importrequire

    $ 所属规范

    require/exports 是 CommonJS/AMD 中为了解决模块化语法而引入的
    import/export 是ES6引入的新规范,因为浏览器引擎兼容问题,需要在node中用babel将ES6语法编译成ES5语法
      关于import在浏览器中被支持的情况如下

    $ 调用时间

    require 是运行时调用,所以理论上可以运作在代码的任何地方
    import 是编译时调用,所以必须放在文件的开头

    $ 本质

    require 是赋值过程,其实require的结果就是对象、数字、字符串、函数等,再把结果赋值给某个变量。它是普通的值拷贝传递。
    import 是解构过程。使用import导入模块的属性或者方法是引用传递。且importread-only的,值是单向传递的。default是ES6 模块化所独有的关键字,export default {} 输出默认的接口对象,如果没有命名,则在import时可以自定义一个名称用来关联这个对象

    $ 语法用法展示

    | require的基本语法

      在导出的文件中使用module.exports对模块中的数据导出,内容类型可以是字符串,变量,对象,方法等不予限定。使用require()引入到需要的文件中即可

      在模块中,将所要导出的数据存放在moduleexport属性中,在经过CommonJs/AMD规范的处理,在需要的页面中使用require指定到该模块,即可导出模块中的export属性并执行赋值操作(值拷贝)



    作者:果汁凉茶丶
    链接:https://www.jianshu.com/p/f1e54dde30c8
    来源:简书
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
    虚心学习、丰富自己
  • 相关阅读:
    Reflector7.5.2.1(最新免费破解版)
    linux shell中变量的特殊处理
    linux中什么是shell?
    关于sql server中主键的一点研究
    根据数据库连接,登录操作系统的一个方法
    无图片取得圆角效果
    结对编程作业(java实现)
    第三章、android入门
    第七章:android应用
    javascript编辑excel并下载
  • 原文地址:https://www.cnblogs.com/tkqq000/p/14944574.html
Copyright © 2011-2022 走看看