当前位置: 首页 > wzjs >正文

小区百货店网怎么做网站危机公关

小区百货店网怎么做网站,危机公关,清河网站建设网络公司,免费发布广告的网站目录 目标 概述 IIFE语法分析 无参数的IIFE 有参数的IIFE Webpack语法分析 基本结构 缓存加载过的模块 ES5的格式 ES6的格式 目标 本文站在js逆向的角度总结知识,所以不讲解Webpack打包技术,只分析模块加载机制。 概述 Webpack Webpack是一个…

目录

目标

概述

IIFE语法分析

无参数的IIFE

有参数的IIFE

Webpack语法分析

基本结构

缓存加载过的模块

ES5的格式

ES6的格式


目标

        本文站在js逆向的角度总结知识,所以不讲解Webpack打包技术,只分析模块加载机制。


概述

Webpack

        Webpack是一个基于模块化的构建工具,它不仅支持JavaScript,还能将CSS、图片、字体等资源统一视作模块,通过Loader转换各种类型的文件,通过Plugin插件机制扩展构建过程,最终生成适合上线部署的静态资源文件。语法结构的特点是:通过自执行函数(IIFE)将所有模块封装起来。这样可以避免全局变量污染,并且确保模块化的封装和依赖的管理。

IIFE(Immediately Invoked Function Expression)

        翻译过来叫做立即执行函数表达式(正式名称),也常常叫它自执行函数。意思是将函数变成表达式,从而达成立刻执行该函数的目的。


IIFE语法分析

无参数的IIFE

//形式一
(function () {console.log("hello world!");
})();
//形式二
!function () {console.log("hello python!");
}();
//形式三
(()=>{console.log("箭头函数!")}
)()

语法分析

        以形式一为案例讲解。它的结构是(function(){……})(),其中:

  • function(){……}是普通的js函数,只是声明并没有执行;
  • 该函数外层括号将其变成了函数表达式;
  • 最右边的括号表示执行垓表达式,同时也可以用它来传递参数。

有参数的IIFE

//形式一
(function (name,age,sex) {console.log(`name:${name};age:${age};sex:${sex}`);
})("张三",14,"男");
//形式二
!function (name,age,sex) {console.log(`name:${name};age:${age};sex:${sex}`);
}("张三",14,"男");
//形式三
((name,age,sex)=>{console.log(`name:${name};age:${age};sex:${sex}`);}
)("张三",14,"男")

Webpack语法分析

基本结构

数组传参

(function fun(e) {//加载器(调用模块的方法)function tx(t) {return e[t].call()}//执行tx方法,tx(1)}
)(//模块[function () {console.log("Java")},function () {console.log("Python")},function () {console.log("Html")},]
)

对象传参

(function fun(e) {//加载器(调用模块的方法)function tx(t) {return e[t].call()}//执行tx方法,tx("py")}
)(//模块{java: function () {console.log("Java")},py: function () {console.log("Python")},html: function () {console.log("Html")},}
)

代码分析

        以数组形式为案例,结构是:(function fun(e){function tx(t){return e[t].call()}tx(1)})([fun1,fun2,fun3……]),其中:

  • 外层是一个自执行函数。结构是:(function(){……})()
  • 这个自执行函数的实际参数是数组或对象,我们叫它模块或者插件。比如:[fun1,fun2,fun3……]
  • 内层函数是加载器,用于执行模块。比如:function tx(t){……}
  • 执行模块的方式是传递数组下标或对象的属性名称。比如:tx(1)
  • 外层函数实际上就是一个闭包,目的就是为了保证各个模块之间互不干扰。想了解闭包的同学,可以进入我的主页查看关于js闭包的文章。

缓存加载过的模块

ES5的格式

(function (e) {var c = {}function fun(t) {//是否是第一次调用if (c[t]) {return c[t].exports}//如果是第一次调用,需要保存到缓存对象c中var o = c[t] = {i: t,l: !1,exports: {}};e[t].call(o.exports, o, o.exports, fun)return o.exports.exports}fun(0)}
)([function () {console.log(1)},function () {console.log(2)},function () {console.log(3)},]
)

ES6的格式

module1.mjs

export function run() {console.log(1);
}

module2.mjs

export function run() {console.log(2);
}

module3.mjs

export function run() {console.log(3);
}

调用文件

import { run as run1 } from './module1.mjs';
import { run as run2 } from './module2.mjs';
import { run as run3 } from './module3.mjs';// 模拟调用模块
const modules = [run1, run2, run3];// 调用第0个模块
modules[1]();

思考:为什么ES6模块不需要手动缓存?

:因为ES6模块天然自带缓存机制。也就是说同一个模块只会被加载一次,第二次import的时候直接复用已经加载的模块实例。

http://www.dtcms.com/wzjs/393548.html

相关文章:

  • 做网站页面设计报价优势的seo网站优化排名
  • 微网站费用2019网站seo
  • 制作网站的设计难点50篇经典软文100字
  • 做平台是做网站和微信小程序的好别做seo有什么好处
  • 优化推广网站seo企业网站的作用有哪些
  • 网站机房建设成本百度助手app下载安装
  • 官网站建设的步骤过程公司网站免费自建
  • 做公司网站要多少钱宁波网站推广优化
  • 触动网站建设广东河源最新疫情
  • 微网站营销是什么谷歌推广公司
  • 上海市建设委员会网站网站域名解析ip查询
  • 如何在微信创建公众号甘肃seo技术
  • 做app的网站有哪些功能湖州网站seo
  • 德吉机械东莞网站建设seo高级教程
  • 企业网站建设需要什么旅行网站排名
  • 海口网站建设公司排名seo权重是什么意思
  • 武汉互联网企业嘉兴百度快照优化排名
  • 最近做网站开发有前途没头条新闻
  • 望城区政府门户网站建设局网络整合营销推广
  • jz做网站今日国际军事新闻最新消息
  • 网站百度搜索第一页网站维护一年一般多少钱?
  • 郴州网站建设公司平台抖音关键词优化排名
  • 网页网站设计培训班百度网站推广申请
  • 用dw做红米网站优化网站关键词
  • 专业做婚庆的网站网络营销的发展概述
  • 新网站怎么做推广跨境电商平台有哪些?
  • 弥勒市建设局网站世界杯大数据
  • 检察网站建设请示英国搜索引擎
  • 什么是门户网站网址大全是ie浏览器吗
  • wordpress网站360搜索收录营销案例分享