import,require具体用法

2020-03-23 15:16:30

参考地址 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属性并执行赋值操作(值拷贝)

// module.jsmodule.exports = {
    a: function() {
        console.log('exports from module');
    }}

// sample.jsvar obj = require('./module.js');obj.a()  // exports from module

当我们不需要导出模块中的全部数据时,使用大括号包含所需要的模块内容。

// module.jsfunction test(str) {
  console.log(str); }module.exports = {
 test}

// sample.js
let { test } =  require('./module.js');
test ('this is a test');

| import 的基本语法

  使用import导出的值与模块中的值始终保持一致,即引用拷贝,采用ES6中解构赋值的语法,import配合export结合使用

// module.jsexport function test(args) {
  console.log(args);}// 定义一个默认导出文件, 一个文件只能定义一次export default {
  a: function() {
    console.log('export from module');
  }}export const name = 'gzc'

// 使用_导出export default的内容import _, { test, name } from './a.js'test(`my name is ${name}`)  // 模板字符串中使用${}加入变量

$ 写法形式

| require/exports 方式的写法比较统一

// requireconst module = require('module')

// exportsexport.fs = fs
module.exports = fs
| import/export 方式的写法就相对丰富些

// importimport fs  from 'fs';import { newFs as fs } from 'fs';  // ES6语法, 将fs重命名为newFs, 命名冲突时常用import { part } from fs;import fs, { part } from fs;

// exportexport default fs;export const fs;export function part;export { part1, part2 };export * from 'fs';

$ 要点总结

  • 通过require引入基础数据类型时,属于复制该变量

  • 通过require引入复杂数据类型时, 属于浅拷贝该对象

  • 出现模块之间循环引用时, 会输出已执行的模块, 未执行模块不会输出

  • CommonJS规范默认export的是一个对象,即使导出的是基础数据类型



  • 2020-02-22 17:35:14

    使用tweenjs写一个发牌的demo

    移动端h5的三大抽奖方式:转盘,老虎机,翻纸牌。 前两样demo比较多,用户也审美疲劳了。这次微信公众号要抽奖,于是调研了下翻纸牌。

  • 2020-02-22 17:45:43

    tweenjs简单快速学习

    tweenjs 是使用 JavaScript 中的一个简单的补间动画库,支持数字、对象的属性和 CSS 样式属性的赋值。 tweenjs 以平滑的方式修改元素的属性值,需要传递给 tween 要修改的值、动画结束时的最终值和动画花费时间(duration),之后 tween 引擎就可以计算从开始动画点到结束动画点之间值,从而产生平滑的动画效果。

  • 2020-02-22 17:47:12

    easeJs入门学习教程

    createjs中包含以下四个部分: EaselJS:用于 Sprites、动画、向量和位图的绘制,创建 HTML5 Canvas 上的交互体验(包含多点触控) TweenJS:用于做动画效果 SoundJS:音频播放引擎 PreloadJS:网站资源预加载

  • 2020-02-22 17:54:59

    最新FullCalendar中文文档

    Fullcalendar是一款用来管理日程安排、工作计划的日历工具,它功能非常强大而且非常实用。而目前网络上没有很好的中文文档,为了更好的和大家分享Fullcalendar的相关使用,即日起计划将Fullcalendar的英文文档翻译成中文版。

  • 2020-02-22 17:57:05

    nuxtjs支持api接口,serverMiddleware

    Who can’t relate to this: You’ve built a small portfolio page for someone, maybe a company, a friend or yourself. And the only API endpoint you’d need is one for a form. What now? Scaffolding a new service just for this one endpoint?

  • 2020-02-22 17:59:34

    FullCalendar插件的基本使用带详细配置翻译

    前段时间,一直在开发考勤系统,当时为满足设计的需求,选了好几个插件,最后决定采用Fullcanlendar的插件。感觉这个插件可以满足现阶段的功能开发需求

  • 2020-02-22 18:03:10

    Vue组件中使用Sass或者Less全局变量

    本文以Sass做案例,Less的参考,基本配置大同小异。 假如我们有一个Sass的全局变量common.scss文件,路径 ../style/common.scss 代码如下: