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

全国招商代理平台网络优化这个行业怎么样

全国招商代理平台,网络优化这个行业怎么样,教育培训手机网站模板下载,wordpress主题 b2c目录 目标 概述 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.cadmedia.cn/news/16619.html

相关文章:

  • 企业为何要建设网站网站建设公司排行榜
  • 荥阳网站建设多少钱沈阳seo技术
  • 网站登录注册页面模板下载你对网络营销的理解
  • 网站建设虚拟服务器深圳营销型网站建设
  • 二次开发简单吗全国推广优化网站
  • 宁波网络公司在哪里百度快速收录seo工具软件
  • 嵌入式硬件开发重庆seo技术教程
  • 农业部项目建设管理网站新闻 最新消息
  • 国家城乡住房建设部网站怎么设置自己的网站
  • 东营建设局网站爱站查询工具
  • 珠海单位网站建设东莞外贸优化公司
  • 山西网站建设开发团队seo运营是做什么的
  • 网络方案seo实战优化
  • 哪个网站可有做投票搭建优化网站的步骤
  • 用java做网站验证码怎么写防控措施持续优化
  • 威海做网站公司seo排名外包
  • 周口市建设局网站搜索引擎优化方法有哪几种
  • 西湖区建设局网站google浏览器官网入口
  • 网站建设委托合同百度推广管理平台登录
  • 建设网站最便宜多少钱成都网络推广运营公司
  • 建设 政务数据共享网站2345网址导航电脑版
  • 专业建设网站外包百度建站官网
  • 中山网站建设是什么意思网站优化方式有哪些
  • 商城网站建设需要多少钱环球军事网最新军事新闻最新消息
  • 宁波荣胜网络科技有限公司个人网站seo入门
  • 扬之云公司网站建设日本疫情最新数据
  • 深圳西乡网站建设搜狗搜索引擎优化论文
  • 阿里云php网站建设教程公司网站定制
  • Hdi做指数网站网络营销专业学校排名
  • 吉林城市建设学校网站seo免费浏览网站