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

网站上做视频如何盈利seo培训费用

网站上做视频如何盈利,seo培训费用,wordpress 文章归档设置,建设工程合同包括三种webpack5新特性 持久化缓存资源模块moduleIds & chunkIds的优化更智能的tree shakingnodeJs的polyfill脚本被移除支持生成e6/es2015的代码SplitChunk和模块大小Module Federation 持久化缓存 缓存生成的webpack模块和chunk,来改善构建速度cache 会在开发模式被设置成 ty…

webpack5新特性

  • 持久化缓存
  • 资源模块
  • moduleIds & chunkIds的优化
  • 更智能的tree shaking
  • nodeJs的polyfill脚本被移除
  • 支持生成e6/es2015的代码
  • SplitChunk和模块大小
  • Module Federation

持久化缓存

  • 缓存生成的webpack模块和chunk,来改善构建速度
  • cache 会在开发模式被设置成 type: 'memory' 而且在 生产 模式 中被禁用
  • 在webpack5中默认开启,缓存默认是在内存里,但可以对cache进行设置
  • 当设置cache.type: "filesystem"的时候,webpack会在内部启用文件缓存和内存缓存,写入的时候会同时写入内存和文件,读取缓存的时候会先读内存,如果内存里没有才会读取文件
  • 每个缓存最大资源占用不超过500MB,当逼近或超过500MB时,会优先删除最老的缓存,并且缓存的有效期最长为2周
  • FileMiddleware.js
  • PackFileCacheStrategy.js:1036
  • FileSystemInfo.js:1691
  • 默认情况下,webpack 假定 webpack 所在的 node_modules 目录只被包管理器修改。对 node_modules 来说,哈希值和时间戳会被跳过

安装

cnpm i webpack webpack-cli webpack-dev-server babel-loader @babel/core  @babel/preset-env -D

webpack.config.js

const path = require('path');
module.exports = {mode: 'development',cache: {type: 'filesystem',  //  'memory' | 'filesystem'cacheDirectory: path.resolve(__dirname, 'node_modules/.cache/webpack'), // 默认将缓存存储在 node_modules/.cache/webpack},watch: true,module: {rules: [{test: /\.js$/,use: [{loader: 'babel-loader',options: {presets: ["@babel/preset-env"]}}]}]}
}

package.json

  "scripts": {"build": "webpack","debug": "webpack"},

资源模块

  • 资源模块(asset module)是一种模块类型,它允许使用资源文件(字体,图标等)而无需配置额外 loader
  • 在 webpack 5 之前,通常使用:
    • raw-loader 将文件导入为字符串
    • url-loader 将文件作为 data URI 内联到 bundle 中
    • file-loader 将文件发送到输出目录
  • 资源模块类型(asset module type),通过添加 4 种新的模块类型,来替换所有这些 loader
    • asset/resource 发送一个单独的文件并导出 URL。之前通过使用 file-loader 实现。
    • asset/inline 导出一个资源的 data URI。之前通过使用 url-loader 实现。
    • asset/source 导出资源的源代码。之前通过使用 raw-loader 实现。
    • asset 在导出一个 data URI 和发送一个单独的文件之间自动选择。之前通过使用 url-loader,并且配置资源体积限制实现
module.exports = {module: {rules: [ {test: /\.png$/,type: 'asset/resource'},{test: /\.ico$/,type: 'asset/inline'},{test: /\.txt$/,type: 'asset/source'}]},experiments: {asset: true},
};

老方式

src\index.js

src\index.js

import url from './images/kf.jpg';
let img = new Image();
img.src = url;
document.body.appendChild(img);

webpack.config.js

webpack.config.js

module: {rules: [{test: /\.(jpg|png|gif)$/,type:'asset'}]
}

新方式

  • 新的方式语法是为了允许在没有打包工具的情况下运行代码。这种语法也可以在浏览器中的原生 ECMAScript 模块中使用

src\index.js

src\index.js

let url = new URL('./images/kf.jpg', import.meta.url);
let img = new Image();
img.src = url;
document.body.appendChild(img);

URIs

  • Webpack 5 支持在请求中处理协议
  • 支持data 支持 Base64 或原始编码,MimeType可以在module.rule中被映射到加载器和模块类型
  • 支持http(s)

src\index.js

import data from "data:text/javascript,export default 'title'";
import url from 'https://img.zhufengpeixun.com/zfjg.png';
console.log(data,url);

webpack.config.js

const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {target: ['es6'],plugins:[new webpack.experiments.schemes.HttpsUriPlugin()]
}

moduleIds & chunkIds的优化

概念

  • module: 每一个文件其实都可以看成一个 module
  • chunk: webpack打包最终生成的代码块,代码块会生成文件,一个文件对应一个chunk

优化

  • 在webpack5之前,没有从entry打包的chunk文件,都会以1、2、3…的文件命名方式输出,删除某些些文件可能会导致缓存失效
  • 在生产模式下,默认启用这些功能chunkIds: “deterministic”, moduleIds: “deterministic”,此算法采用确定性的方式将短数字 ID(3 或 4 个字符)短hash值分配给 modules 和 chunks
可选值含义示例
false不应使用任何内置算法,插件提供自定义算法Path variable [name] not implemented in this context: [name].js
natural按使用顺序的数字ID1
named方便调试的高可读性idsrc_two_js.js
deterministic根据模块名称生成简短的hash值915
size根据模块大小生成的数字id0
const path = require('path');
module.exports = {mode: 'development',devtool:false,
+    optimization:{
+        moduleIds:'deterministic',
+        chunkIds:'size'
+    },module: {rules: [{test: /\.js$/,use: [{loader: 'babel-loader',options: {presets: ["@babel/preset-env"]}}]}]}
}

移除Node.js的polyfill

  • webpack4带了许多Node.js核心模块的polyfill,一旦模块中使用了任何核心模块(如crypto),这些模块就会被自动启用
  • webpack5不再自动引入这些polyfill

安装

cnpm i crypto-js crypto-browserify stream-browserify buffer -D

src\index.js

import CryptoJS from 'crypto-js';
console.log(CryptoJS.MD5('zhufeng').toString());

webpack.config.js

    resolve:{/* fallback:{ "crypto": require.resolve("crypto-browserify"),"buffer": require.resolve("buffer"),"stream":require.resolve("stream-browserify")}, */fallback:{ "crypto":false,"buffer": false,"stream":false}},

更强大的tree-shaking

  • tree-shaking
  • webpack4 本身的 tree shaking 比较简单,主要是找一个 import 进来的变量是否在这个模块内出现过,非常简单粗暴

原理

  • webpack从入口遍历所有模块的形成依赖图,webpack知道那些导出被使用
  • 遍历所有的作用域并将其进行分析,消除未使用的范围和模块的方法
  • webpack-deep-scope-demo
  • webpack-deep-scope-analysis-plugin

作用域

  • 而对于一个模块来说,只有 classfunction 的作用域是可以导出到其他模块的
// module scope start// Block{ // <- scope start} // <- scope end// Classclass Foo { // <- scope start//   |       }       // <- scope end// If elseif (true) { // <- scope start} /* <- scope end */ else { // <- scope start} // <- scope end// Forfor (;;) { // <- scope start} // <- scope end// Catchtry {} catch (e) { // <- scope start} // <- scope end// Functionfunction() { // <- scope start} // <- scope end// Scopeswitch() { // <- scope start} // <- scope end// module scope end

开启

开发环境

webpack.config.js

const path = require('path');module.exports = {entry: './src/index.js',output: {filename: 'bundle.js',path: path.resolve(__dirname, 'dist'),},mode: 'development',optimization: {usedExports: true,},
};

生产环境

  • 生产环境默认开启

sideEffects

  • "sideEffects": false,意思就是对所有的模块都进行Tree Shaking
  • 也就是将没有引入的方法等不进行打包到打包输出文件中

package.json

{"sideEffects": ["@babel/polyfill"]}
{"sideEffects": ["*.css"]}

嵌套的 tree-shaking

  • webpack 现在能够跟踪对导出的嵌套属性的访问
  • 这可以改善重新导出命名空间对象时的Tree Shaking(清除未使用的导出和混淆导出)

src\index.js

src\index.js

import * as calculator from "./calculator";
console.log(calculator.operators.add);

src\calculator.js

src\calculator.js

import * as operators from "./operators";
export { operators };

src\operators.js

src\operators.js

export const add = 'add';
export const minus = 'minus';

webpack.config.js

webpack.config.js

module.exports = {mode: 'production'
}

内部模块 tree-shaking

  • webpack 4 没有分析模块的导出和引用之间的依赖关系
  • webpack 5 可以对模块中的标志进行分析,找出导出和引用之间的依赖关系

src\index.js

src\index.js

import { getPostUrl } from './api';
console.log('getPostUrl',getPostUrl);

src\api.js

src\api.js

import { host } from './constants';function useHost() {return host;
}export function getUserUrl() {return useHost()+'/user';
}
export function getPostUrl() {return '/post';
}

src\api.js

src\api.js

export const host = 'http://localhost';

CommonJs Tree Shaking

  • webpack 曾经不进行对 CommonJS 导出和 require()调用时的导出使用分析
  • webpack 5 增加了对一些 CommonJS 构造的支持,允许消除未使用的 CommonJs 导出,并从 require() 调用中跟踪引用的导出名称 支持以下构造:
  • exports|this|module.exports.xxx = …
  • exports|this|module.exports = require(“…”) (reexport)
  • exports|this|module.exports.xxx = require(“…”).xxx (reexport)
  • Object.defineProperty(exports|this|module.exports, “xxx”, …)
  • require(“abc”).xxx
  • require(“abc”).xxx()

src\index.js

src\index.js

let api = require('./api');
console.log(api.getPostUrl);

src\api.js

src\api.js

function getUserUrl() {return '/user';
}
function getPostUrl() {return '/post';
}exports.getPostUrl=getPostUrl;

splitChunks

  • split-chunks-plugin
http://www.dt0577.cn/news/25883.html

相关文章:

  • 计算机速成班培训优化大师有必要花钱吗
  • 那个网站可以做域名跳转的seo站内优化和站外优化
  • 团风做网站如何做平台推广
  • 抖音小程序怎么添加搜索引擎优化的主要策略
  • 做视频特效的网站有哪些国内疫情最新情况
  • 用什么系统程序做评测网站怎么做线上销售
  • 个人免费注册公司网站营销渠道有哪些
  • 网站备案授权书沙坪坝区优化关键词软件
  • wordpress开发难吗seo臻系统
  • 公司网站开发主要技术广州seo推广营销
  • 做网站和做微信小程序优量汇广告平台
  • 织梦网站需要优化如何做好网络销售技巧
  • 佛山网站建设no.1沪深300指数
  • wordpress添加磁力下载地址台州关键词首页优化
  • 网站获取访问者qq号码关键词免费
  • 建站网址网站如何优化排名
  • wordpress备份到dropbox许昌seo公司
  • 做袜子娃娃的网站免费引流推广工具
  • 18末年年禁止观看网站营销型网站建设方案
  • 表格做网站seo入门视频
  • 网站建设html5作品云南网站建设公司哪家好
  • 国内网页设计网站网络推广公司主要做什么
  • 简单一点的网站建设成都网站建设创新互联
  • wordpress is front优化营商环境工作总结
  • 求一个网站淘宝推广方式
  • 网上做网站的上海seo推广平台
  • 衡水专业制作网站网站功能开发
  • 广州市财经商贸职业学校seo外链在线工具
  • 山东济南网站建设公司谷歌搜索引擎免费入口 台湾
  • 游戏币销售网站建设今日足球最新预测比分