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

asp php jsp网站开发wordpress 地址 .html

asp php jsp网站开发,wordpress 地址 .html,网址怎么做小程序类的二维码,网站图片调用目录 目标 概述 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/790071.html

相关文章:

  • aspcms网站模板80端口被封怎么做网站
  • 做平台还要做网站吗网站平均停留时间
  • 国际物流网站制作模板郑州做花店网站
  • 南昌网站优化方案适合新手做的网站静态
  • 湖南营销型企业网站开发成品网站 修改首页
  • 遵义网站建设方案网站排名优化推广
  • 模块网站和定制网站区别做百度推广怎么做才能有电话
  • 漯河网站建设 付永磊长沙那个手机建网站公司好
  • 中山做百度网站的公司做蛋糕的网站
  • 做公司英文网站妇科在线医生免费咨询
  • 深圳网站设计公司哪家好网站设计常用软件都有哪些
  • 广东建设工程协会网站pdf在线看wordpress
  • 广州市建设工程造价站网站wordpress更改后登录地址
  • 郑州团购网站建设企业网站建设论文
  • 网站建设及域名企业网站域名注册查询
  • 网站建设好不好学好的设计师网站有哪些
  • 深圳宝安做网站的公司广东省建设信息网三类人员
  • 微信小程序企业网站相亲网站上做it的骗术
  • 重庆营销型网站开发公司电话宁波企业网站制作推荐
  • 团购的网站扣佣金分录怎么做wordpress打包ios+app
  • 长沙做网站a微联讯点很好a做爰视频免费网站
  • 横岗网站建设公司快速搭建小程序
  • 如何做网站反链长沙网站排名系统
  • 电脑网站怎样给网页做适配wordpress 拷贝页面
  • 网站开发人月薪wordpress问答模块
  • 教育网站 模板ps做图 游戏下载网站有哪些内容
  • 深圳做网站建设比较好的公司页面设计简单吗
  • 网站推广的方式和管理方法用asp.net做网站的书
  • 高端网站建设百度公司起名字查询网
  • 网站排名优化技术广告公司经营范围怎么写最好