@charset "UTF-8";
.markdown-body { line-height: 1.75; font-weight: 400; font-size: 15px; overflow-x: hidden; color: rgba(43, 43, 43, 1); font-family: -apple-system, system-ui, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Hiragino Sans GB, Microsoft YaHei, Arial, sans-serif; background-image: linear-gradient(90deg, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0), linear-gradient(1turn, rgba(159, 219, 252, 0.15) 3%, rgba(0, 0, 0, 0) 0); background-size: 20px 20px; background-position: center }
.markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4, .markdown-body h5, .markdown-body h6 { padding: 30px 0; margin-top: 35px; margin-bottom: 10px; color: rgba(77, 208, 225, 1) }
.markdown-body h1 { font-size: 30px; text-align: center; position: relative; width: max-content; margin: 0 auto }
.markdown-body h1:before { position: absolute; content: ""; z-index: -1; top: -20px; height: 100%; width: 100px; left: 0; right: 0; margin: 0 auto; background: url("") center / 64px 64px no-repeat; opacity: 0.84 }
.markdown-body h1:after { position: absolute; content: ""; width: 150%; left: -25%; height: 50%; bottom: 12px; border-radius: 50%; background: linear-gradient(rgba(0, 0, 0, 0) 80%, rgba(77, 208, 225, 0.8)); opacity: 0.6; animation: 6s linear infinite h1animate }
@keyframes h1Animate { 0% { background-position: right bottom } 50% { background-position: right } 100% { background-position: right bottom } }
.markdown-body h2 { display: block; border-bottom: 4px solid rgba(77, 208, 225, 1); position: relative; font-size: 24px; padding: 12px 32px; margin: 30px 0 }
.markdown-body h2:before { width: 24px; height: 24px; left: 0; top: 0; margin: auto; background-size: 24px 24px; background-image: url("") }
.markdown-body h2:after, .markdown-body h2:before { content: ""; display: block; position: absolute; bottom: 0 }
.markdown-body h2:after { right: 0; width: 400px; height: 10px; border-top-right-radius: 24px; background: linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(77, 208, 225, 1)); max-width: 50vw }
.markdown-body h3 { margin: 30px 0; font-size: 18px; position: relative; padding: 4px 32px; width: max-content }
.markdown-body h3:before { border-bottom: 2px solid rgba(77, 208, 225, 1); width: 100%; content: ""; display: block; height: 28px; position: absolute; left: 0; top: 0; bottom: -2px; margin: auto; background-size: 28px 28px; background-image: url(""); background-repeat: no-repeat; animation: 2s infinite alternate h3animationbefore }
@keyframes h3AnimationBefore { 0% { width: 28px } 25% { width: 100% } 50% { width: 100% } 100% { width: 100% } }
.markdown-body h3:after { content: ""; display: block; width: 28px; height: 28px; position: absolute; border: 2px solid rgba(77, 208, 225, 1); border-radius: 50%; right: -15px; top: 0; bottom: 0; margin: auto; background-size: 28px 28px; background-image: url(""); animation: 2s infinite alternate h3animationafter }
@keyframes h3AnimationAfter { 0% { } 10% { } 50% { transform: rotate(-1turn) } 100% { transform: rotate(-1turn) } }
.markdown-body h4 { font-size: 16px }
.markdown-body h5 { font-size: 15px }
.markdown-body h6 { margin-top: 5px }
.markdown-body p { line-height: inherit; margin: 22px 0; letter-spacing: 2px; font-size: 14px; word-spacing: 2px }
.markdown-body img { max-width: 80%; border-radius: 6px; display: block; margin: 20px auto !important; object-fit: contain; box-shadow: 0 0 16px rgba(110, 110, 110, 0.45) }
.markdown-body figcaption { display: block; font-size: 13px; color: rgba(43, 43, 43, 1) }
.markdown-body figcaption:before { content: ""; background-image: url(""); display: inline-block; width: 18px; height: 18px; background-size: 18px; background-repeat: no-repeat; background-position: center; margin-right: 5px; margin-bottom: -5px }
.markdown-body hr { border-top: 1px solid rgba(77, 208, 225, 1); border-right: none; border-bottom: none; border-left: none; margin-top: 32px; margin-bottom: 32px }
.markdown-body del { color: rgba(77, 208, 225, 1) }
.markdown-body code { border-radius: 2px; overflow-x: auto; background-color: rgba(77, 208, 225, 0.08); color: rgba(38, 198, 218, 1); padding: 0.195em 0.4em }
.markdown-body pre { font-family: Menlo, Monaco, Consolas, Courier New, monospace; overflow: auto; position: relative; line-height: 1.75; box-shadow: 0 0 8px rgba(110, 110, 110, 0.45); border-radius: 4px; margin: 16px }
.markdown-body pre:before { content: ""; display: block; height: 30px; width: 100%; margin-bottom: -7px; background: url("") 10px 10px / 40px no-repeat }
.markdown-body pre>code { font-size: 12px; padding: 15px 12px; margin: 0; word-break: normal; display: block; overflow-x: auto; color: rgba(51, 51, 51, 1); background: rgba(248, 248, 248, 1) }
.markdown-body a { color: rgba(77, 208, 225, 1); border-bottom: 1px solid rgba(77, 208, 225, 1); font-weight: 400; text-decoration: none; margin: 0 4px }
.markdown-body a:active, .markdown-body a:hover { background-color: rgba(77, 208, 225, 0.1) }
.markdown-body strong { color: rgba(38, 198, 218, 1) }
.markdown-body strong:before { content: "「" }
.markdown-body strong:after { content: "」" }
.markdown-body em { font-style: normal; color: rgba(77, 208, 225, 1); font-weight: 700 }
.markdown-body table { display: inline-block !important; font-size: 12px; width: auto; max-width: 100%; overflow: auto; border: 1px solid rgba(246, 246, 246, 1) }
.markdown-body thead { background: rgba(246, 246, 246, 1); color: rgba(0, 0, 0, 1); text-align: left }
.markdown-body tr:nth-child(2n) { background-color: rgba(77, 208, 225, 0.05) }
.markdown-body td, .markdown-body th { padding: 12px 7px; line-height: 24px }
.markdown-body td { min-width: 120px }
.markdown-body blockquote { margin: 2em 0; padding: 24px 32px; border-left: 4px solid rgba(38, 198, 218, 1); background: rgba(77, 208, 225, 0.15); position: relative }
.markdown-body blockquote:before { content: "❝"; top: 8px; left: 8px; color: rgba(77, 208, 225, 1); font-size: 30px; line-height: 1; font-weight: 700; position: absolute; opacity: 0.7 }
.markdown-body blockquote:after { content: "❞"; font-size: 30px; position: absolute; right: 8px; bottom: 0; color: rgba(77, 208, 225, 1); opacity: 0.7 }
.markdown-body blockquote p { color: rgba(89, 89, 89, 1); line-height: 2 }
.markdown-body ol, .markdown-body ul { color: rgba(89, 89, 89, 1); padding-left: 28px }
.markdown-body ol li, .markdown-body ul li { margin-bottom: 0; list-style: inherit }
.markdown-body ol li .task-list-item, .markdown-body ul li .task-list-item { list-style: none }
.markdown-body ol li .task-list-item ol, .markdown-body ol li .task-list-item ul, .markdown-body ul li .task-list-item ol, .markdown-body ul li .task-list-item ul { margin-top: 0 }
.markdown-body ol ol, .markdown-body ol ul, .markdown-body ul ol, .markdown-body ul ul { margin-top: 3px }
.markdown-body ol li { padding-left: 6px }
@media (max-width: 720px) { .markdown-body h1 { font-size: 24px } .markdown-body h2 { font-size: 20px } .markdown-body h3 { font-size: 18px } }.markdown-body pre, .markdown-body pre>code.hljs { background: rgba(255, 255, 255, 1); color: rgba(0, 0, 0, 1) }
.hljs-comment, .hljs-quote, .hljs-variable { color: rgba(0, 128, 0, 1) }
.hljs-built_in, .hljs-keyword, .hljs-name, .hljs-selector-tag, .hljs-tag { color: rgba(0, 0, 255, 1) }
.hljs-addition, .hljs-attribute, .hljs-literal, .hljs-section, .hljs-string, .hljs-template-tag, .hljs-template-variable, .hljs-title, .hljs-type { color: rgba(163, 21, 21, 1) }
.hljs-deletion, .hljs-meta, .hljs-selector-attr, .hljs-selector-pseudo { color: rgba(43, 145, 175, 1) }
.hljs-doctag { color: rgba(128, 128, 128, 1) }
.hljs-attr { color: rgba(255, 0, 0, 1) }
.hljs-bullet, .hljs-link, .hljs-symbol { color: rgba(0, 176, 232, 1) }
.hljs-emphasis { font-style: italic }
.hljs-strong { font-weight: 700 }

JavaScript的重要性和普遍性

JavaScript作为一种广泛使用的编程语言,在前端开发中发挥着重要的作用。它被用于构建网页的交互功能、移动应用程序以及服务器端的开发。因此,了解如何优化和压缩JavaScript代码对于提升用户体验和加快页面加载速度至关重要。

极致性能优化与代码大小压缩的意义

极致性能优化和代码大小压缩的目标是使网页加载更快、响应更迅速。这对于提高用户的满意度、减少用户等待时间以及提升网页在搜索引擎排名中的竞争力都是至关重要的。

一、理解性能优化的核心原则

1. 代码执行效率分析

了解JavaScript代码的执行效率是优化的第一步。可以使用性能分析工具来识别潜在的性能瓶颈,例如Chrome DevTools中的Performance面板或者Web性能测试工具。通过分析执行时间和资源消耗,可以有针对性地进行优化。

2. 减少CPU和内存消耗的策略

减少CPU和内存的消耗可以通过使用优化的算法和数据结构、避免过度递归调用、合理使用循环和条件语句等方式实现。举个例子,假设我们需要对一个数组中的元素进行求和:

// 不优化的写法
function sum(array) {
let result = 0;
for (let i = 0; i < array.length; i++) {
result += array[i];
}
return result;
} // 优化后的写法
function sum(array) {
return array.reduce((acc, current) => acc + current, 0);
}

3. 避免不必要的网络请求

减少不必要的网络请求可以大幅提升页面加载速度。常见的优化方式包括合并和压缩CSS和JavaScript文件、使用CSS Sprites来减少图片请求数量、使用缓存来避免重复请求等。现在,我们来看一个使用CSS Sprites的例子:

<!-- 不使用CSS Sprites的写法 -->
<img src="data:image1.png">
<img src="data:image2.png">
<img src="data:image3.png"> <!-- 使用CSS Sprites的写法 -->
<div class="sprite sprite-image1"></div>
<div class="sprite sprite-image2"></div>
<div class="sprite sprite-image3"></div> <style>
.sprite {
background-image: url(sprites.png);
background-repeat: no-repeat;
} .sprite-image1 {
width: 100px;
height: 100px;
background-position: 0 0;
} .sprite-image2 {
width: 200px;
height: 200px;
background-position: -100px 0;
} .sprite-image3 {
width: 150px;
height: 150px;
background-position: -300px 0;
}
</style>

二、极致性能优化技术探索

1. 懒加载和预加载

懒加载和预加载是提高网页性能的重要手段。懒加载指的是延迟加载页面中的非关键资源,直到用户需要访问它们。预加载则是在网页加载过程中提前加载将要使用的资源。下面是一个图片懒加载的例子:

<img src="placeholder.jpg" data-src="data:image.jpg" class="lazy-load-image">

<script>
const lazyLoadImages = document.querySelectorAll(".lazy-load-image"); const intersectionObserver = new IntersectionObserver((entries, observer) => {
entries.forEach(entry => {
if (entry.isIntersecting) {
const img = entry.target;
img.src = img.dataset.src;
observer.unobserve(img);
}
});
}); lazyLoadImages.forEach(image => {
intersectionObserver.observe(image);
});
</script>

2. 代码分割和按需加载

代码分割和按需加载可以将大型的JavaScript文件分割成较小的块,并在需要时动态加载。这样可以减少首次加载的时间,并且只加载当前页面需要的代码。下面是一个使用Webpack进行代码分割和按需加载的例子:

// 懒加载模块
import("./module.js")
.then(module => {
// 使用模块
module.doSomething();
})
.catch(err => {
console.error("模块加载失败:", err);
});

3. 图像和资源优化技巧

优化图像和其他资源的大小可以减少网络传输的数据量,从而提升页面加载速度。可以使用图像压缩工具、适当选择图像格式、减少资源文件的数量等方式进行优化。以下是一个对图像进行压缩和优化的示例:

// 使用canvas来压缩图片
function compressImage(input, maxWidth, maxHeight, quality) {
return new Promise((resolve, reject) => {
if (!input) {
reject(new Error("未选择图片"));
} const reader = new FileReader();
reader.readAsDataURL(input); reader.onloadend = function() {
const img = new Image();
img.src = reader.result; img.onload = function() {
const canvas = document.createElement("canvas");
let width = img.width;
let height = img.height; if (width > height) {
if (width > maxWidth) {
height *= maxWidth / width;
width = maxWidth;
}
} else {
if (height > maxHeight) {
width *= maxHeight / height;
height = maxHeight;
}
} canvas.width = width;
canvas.height = height; const ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0, width, height); canvas.toBlob(
function(blob) {
resolve(blob);
},
'image/jpeg',
quality
);
}; img.onerror = function() {
reject(new Error("无法加载图像"));
};
}; reader.onerror = function() {
reject(new Error("读取文件错误"));
};
});
} // 调用示例函数进行图像优化
const inputFile = document.getElementById("inputFile"); // 输入图像文件的input元素
const compressButton = document.getElementById("compressButton"); // 压缩按钮 compressButton.addEventListener("click", async () => {
const inputFiles = inputFile.files;
if (inputFiles.length > 0) {
const input = inputFiles[0];
const maxWidth = 800; // 最大宽度
const maxHeight = 800; // 最大高度
const quality = 0.8; // 图像质量 try {
const compressedImage = await compressImage(input, maxWidth, maxHeight, quality);
console.log(compressedImage);
// 在此处上传或处理压缩后的图像文件
} catch (error) {
console.error(error);
}
}
});

上述代码中,我们使用了HTML5的Canvas和File API来对图像进行处理。代码中的compressImage函数接受四个参数:输入图像文件、最大宽度、最大高度和图像质量。它会将图像加载到canvas中,在保持宽高比的情况下缩放图像,并最终输出压缩后图片的Blob对象。

代码还包括了一个用于触发图像压缩处理的按钮,并使用该按钮的点击事件监听器来调用compressImage函数。你可以将该代码与你的页面中的HTML元素和事件处理器集成,以实现图像压缩和优化的功能。


## 三、极致代码大小压缩技术解析 ### 1. JavaScript的压缩和混淆 JavaScript的压缩和混淆可以去除多余的空格、注释以及简化变量名,从而减小代码的体积。常用的工具有UglifyJS和Terser。下面是一个使用Terser进行代码压缩的例子: ```bash
npx terser script.js -o script.min.js

2. Tree Shaking和无用代码剔除

Tree Shaking是一种利用静态代码分析的技术,通过识别和移除未使用的代码,减小打包后文件的大小。在Webpack中,可以通过配置进行开启。以下是一个使用Tree Shaking的例子:

import { module1, module2, module3 } from "./modules.js";

// 使用module1
module1(); // 使用module2
module2(); // module3没有被使用,会被Tree Shaking移除

3. 模块化加载器的选择和优化

选择合适的模块化加载器可以在打包时进行一些优化,例如代码分割、按需加载等。常用的模块化加载器有Webpack和Rollup。下面是一个使用Webpack进行模块化加载的例子:

import module1 from "./module1.js"

// 使用module1
module1.doSomething();

四、最佳实践和工具推荐

1. 代码规范和优化

遵循统一的代码规范有助于提高代码的可读性和维护性。使用工具如ESLint可以帮助发现代码中的潜在问题,并提供优化建议。

2. 性能分析工具的使用

使用性能分析工具,例如Chrome DevTools的Performance面板、Lighthouse等,可以帮助识别性能瓶颈并进行优化。

3. 压缩工具和资源优化库推荐

有许多优秀的工具和库可供选择,例如gzip、Babel和WebP等。根据具体情况选择合适的工具和库来优化代码和资源。

结论

极致性能优化和代码大小压缩是提高网页性能和用户体验的重要手段。通过理解性能优化的核心原则,探索极致性能优化技术和代码大小压缩技术,以及采用最佳实践和工具,我们可以有效地优化JavaScript代码,提升网页加载速度。

深入探索JavaScript的黑科技:剖析极致性能优化和代码大小压缩的更多相关文章

  1. 这些JavaScript编程黑科技

    1.单行写一个评级组件 "★★★★★☆☆☆☆☆".slice(5 - rate, 10 - rate);定义一个变量rate是1到5的值,然后执行上面代码,看图 才发现插件什么的都 ...

  2. 黑科技!仅需 3 行代码,就能将 Gitter 集成到个人网站中,实现一个 IM 即时通讯聊天室功能?

    欢迎关注个人微信公众号: 小哈学Java, 文末分享阿里 P8 高级架构师吐血总结的 <Java 核心知识整理&面试.pdf>资源链接!! 个人网站: https://www.ex ...

  3. 46、Spark SQL工作原理剖析以及性能优化

    一.工作原理剖析 1.图解 二.性能优化 1.设置Shuffle过程中的并行度:spark.sql.shuffle.partitions(SQLContext.setConf()) 2.在Hive数据 ...

  4. 这些JavaScript编程黑科技,装逼指南,高逼格代码,让你惊叹不已

    Javascript是一门很吊的语言,我可能学了假的JavaScript,哈哈,大家还有什么推荐的,补充送那啥邀请码. 本文秉承着:你看不懂是你SB,我写的代码就要牛逼. 1.单行写一个评级组件 &q ...

  5. javascript的页面加载及性能优化(兼容IE7)

    通常来说,window.onload就够用了,如果想加载多个事件,我们可以采取以下方式: window.onload = function(){        func1();        func ...

  6. javascript DOM编程艺术(检测与性能优化)

    一.对象检测(是否支持js方法):只有支持了该方法才可调用 if(!getElementById || getElementsByTagName){ return false; } 二.性能考滤 1. ...

  7. 【基本功】深入剖析Swift性能优化

    简介 2014年,苹果公司在WWDC上发布Swift这一新的编程语言.经过几年的发展,Swift已经成为iOS开发语言的“中流砥柱”,Swift提供了非常灵活的高级别特性,例如协议.闭包.泛型等,并且 ...

  8. 深入剖析Swift性能优化

    简介 2014年,苹果公司在WWDC上发布Swift这一新的编程语言.经过几年的发展,Swift已经成为iOS开发语言的“中流砥柱”,Swift提供了非常灵活的高级别特性,例如协议.闭包.泛型等,并且 ...

  9. 深入剖析 iOS 性能优化

    问题种类 时间复杂度 在集合里数据量小的情况下时间复杂度对于性能的影响看起来微乎其微.但如果某个开发的功能是一个公共功能,无法预料调用者传入数据的量时,这个复杂度的优化显得非常重要了.上图列出了各种情 ...

  10. 聊聊H5与JS近几年的黑科技

    聊聊H5与JS近几年的黑科技 自ajax技术的诞生,编程界兴起了一股WEB开发热,facebook,Twitter等众多大佬级企业都在网页应用上大放异彩,这十年我们见证了前端技术的崛起.这期间产生了众 ...

随机推荐

  1. [SDOI2015] 序列统计 题解

    乘法并不容易用 FFT 或 NTT 维护,考虑在模意义下化乘为加. 化乘为加主要有两种方法:\(\log\) 和 \(\gamma\)(指标),由于在取模意义下,所以使用后者. 那剩下的部分就是快速幂 ...

  2. Android应用借助LinearLayout实现垂直水平居中布局

    首先说的是LinearLayout布局下的居中一般是这样的: (注意:android:layout_width="fill_parent" android:layout_heigh ...

  3. 最优化方法之AdaGrad、RMSProp、Adam

    结论: 1.简单来讲,设置全局学习率之后,每次通过,全局学习率逐参数的除以历史梯度平方和的平方根,使得每个参数的学习率不同 2.效果是:在参数空间更为平缓的方向,会取得更大的进步(因为平缓,所以历史梯 ...

  4. TensorFlow 的基本概念和使用场景

    TensorFlow是一个开源的机器学习框架,由Google开发并维护.它提供了一个灵活的编程环境,用于构建和训练各种机器学习模型.TensorFlow是基于图计算的模型,其中节点表示数学操作,而边表 ...

  5. [爬坑指南] 虚拟机和docker实现下载服务器

    现在需要挂梯子下载一批资源,然而我的梯子装在路由器中,openclash只能配置指定的某个设备不走梯子.所以索性就装个虚拟机专门用来下载东西,挂bt.如果需要走梯子,就单独在这个下载机中配置一个廉价梯 ...

  6. csharp入门经典

    C#简介 .NET Framework是Microsoft为开发应用程序而创建的一个具有革命意义的平台,它有运行在其他操作系统上的版本 .NET Framework的设计方式确保它可以用于各种语言,包 ...

  7. C# 将list进行随机排序

    private List<T> RandomSortList<T>(List<T> ListT) { Random random = new Random(); L ...

  8. qa 工作

    1.定流程--监控参照规范(cmmi,公司自己的,scrum[例会.启动会])--产出物报告 (项目维度)-配置--经盈.财务 2.培训组织-组织讲师(知识库).外部拓展

  9. 张高兴的大模型开发实战:(一)使用 Selenium 进行网页爬虫

    目录 什么是 Selenium 环境搭建与配置 安装 Selenium 下载浏览器驱动 基础操作 启动浏览器并访问网页 定位网页元素 通过 ID 定位 通过 CSS 选择器定位 通过 XPath 定位 ...

  10. 微信小程序获取环境变量

    微信小程序获取环境变量 在微信小程序中,无法直接获取环境变量.但是,我们可以通过其他方式来模拟环境变量的功能. 参考用法 通过 wx.getAccountInfoSync() 获取小程序信息,包含小程 ...