学习路线指引(点击解锁) | 知识定位 | 人群定位 |
---|---|---|
Python实战微信订餐小程序 | 进阶级 | 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。 |
Python量化交易实战 | 入门级 | 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统 |
事件委托(也叫事件代理)利用了事件冒泡,把监听函数绑定在父容器上。在触发DOM上的某个事件时,会产生一个事件对象event,这个对象中包含着所有与事件有关的信息。
使用事件委托的优点:
a.减少DOM操作,使事件处理时间减少。
b.减少内存空间的使用,提升性能。
简单例子:
let myUl = document. getElementByld("my-ul");
myUl.addEventListener('click',function(e){
if(e.target.tagName == "LI"){
//如果点击的目标的标签名为LI
alert(e.target.innerText)
}
})
可见文章:https://blog.csdn.net/qq_32442973/article/details/118739927
WebP是Google推出的一种同时提供有损压缩与无损压缩的图片文件格式,派生自图像编码格式VP8,支持透明图层和多图片动图。
WebP可对网页图片有效进行压缩而不影响图片清晰度,从而节省带宽,提高图片下载速度。在质量相同的情况下,WebP格式图像的体积要比JPEG格式图像小40%,比PNG文件小26%。
Google提供了 WebP文件解码器(libvpx)和 命令行工具(webpconv),用于JEPG、png等格式图片与WebP格式之间的转换。WebP目前支持Chrome内核、Edgel8+、Safari 14+、Android的WebView等
浏览器,不支持ie。
方法一:前端js判断加载
对浏览器进行判断是否支持WebP,先加载一张base64的WebP格式,根据宽高来判断是否支持。如果支持则加载默认的WebP格式的图片,如果不支持则把img标签里的图片后缀换成常规的jpg或png即可。
function checkWebp(callback) {
var img = new Image();
img.onload = function () {
var result = (img.width>0) && (img.height>0);
callback(result);
};
img.onerror = function () {
callback(false);
};
img.src = '';
}
function showlmage(flag){
var imgs = Array.from(document.querySelectorAll('img'))
imgs.forEach(function(i){
var src = i.attributes['data-src'].value
if(flag){
i.src = src
}else{
src = src.replace(/\.webp$/,'.jpg')
}
})
}
checkWebp(showlmage)
方法二:前端picture标签
如果浏览器支持WebP格式,就会加载 a.webp,否则会加载a.jpg。
方法三:服务端响应不同格式
支持webp图片的浏览器在向服务器发送请求时,会在请求头Accept中带上image/webp,然后服务器根据是否含有这个头信息来决定返回webp或其它格式图片。很多云服务器和CDN带有这种WebP自适应功能。
seo(Search Engine Optimization)即搜索引擎优化,就是通过总结搜索引擎的运作规则,对网站进行合理的优化以提高网站在搜索引擎的排名。 搜索引擎通过爬虫(蜘蛛)程序按一定规则抓取收录你的网页,分析处理后按关键字建立索引,以便为用户提供快速检索网页的服务。seo就是通过挖掘用户搜索习惯,设 定用户所搜索的关键词,优化网站定位和布局,填充优质网站内容,使网页符合爬虫胃口,获得搜索引擎信任,在不损害用户体验的情况下使网站排名靠在搜索引擎前列,从而提高网站访问量。
做法:
Base64是一种编码算法,使用64个可打印字符(“A-Z,a-z,0-9, +,/”,'='号就是65个)来对任意数据进行编码。
通常用于将二进制数据(如图片)转化为可打印字符,方便存储和http传输。
Base64不是真正的加密算法,可以被任何人编码解码。可以使用base64在线编码解码工具。
前端应用:
1.html直接嵌入Base64编码图片,避免不必要的外部资源请求。
.bg{
background:url(...)
}
(不适用色彩丰富的大图片,其编码后字符串较大,增加html/css体积,影响页面加载速度)
2.canvas的toDataURL
将canvas画布内容转为base64编码格式后传递到后端,后端base64解码保存。
3.FileReader的readAsDataURL
将上传的文件转为base64格式提交到服务器,如用户头像。
字体图标( iconfont) 将svg矢量图标作成字体,采用字体格式来显示网页中的的纯色图标。同字体使用一样,在css中通过@font-face定义,通过color, font-size等改变图标的颜色,大小等样式。
uni-app种使用字体图标
先
https://blog.csdn.net/qq_45018844/article/details/120757230
再
https://blog.csdn.net/qq_45018844/article/details/120827906
普通项目使用字体图标
https://blog.csdn.net/qq_48386796/article/details/119061059
lazy-load(懒加载)就是按需加载图片,等图片出现在浏览器当前视窗内再去加载,这样不用一次性加载全部内容,减少首屏时请求数,缓解浏览器和服务器压力,节省流量。
实现原理:
若在src中填入图片地址,浏览器就可以发起请求,加载一张图片。要实现懒加载,可以定义一个虚拟src属性即data-src存放原图地址,而属性src填写
一张低质量的空白占位图。当页面滚动时,遍历图片判断是否在可视区域内,如果在则将data-src中真实地址放到src中,实现按需加载。另外页面滚动是一个触发频繁的事件,可以利用防抖或节流函数优化一下。
gzip是一种数据压缩格式,是HTTP协议上的GZIP编码。
一般用于服务器将静态文件压缩后传输到客户端,可压缩到原大小的4 0% ,大大节
省网络带宽,提高访问速度。
启 用g z i p需 要 客 户 端 和 服 务 端 的 共 同 支持,现在主流浏览器和常见服务器都是支持gzip的。
gzip工作原理
CDN ( Content Delivery Network,内容分发网络),是一组分布在多个不同地理
位置的WEB服务器(缓存服务器),用于有效的向用户分发内容。
主要原理
就是将源站的静态资源(图片视频、html/css/jss安装包apk等)缓存到位于不同区域的CDN节点服务器上,通常是终端网络提供商的机房,当用户访问网站时,会去离用户距离最近的CDN服务器上获取,从而避免了网络拥塞,提高了访问速度,缓解了源站压力。
具体流程
Lighthouse是Google开源的一个自动化的网站性能测评工具。主要功能是检测网站的性能,分析网络应用和网页,收集现代性能指标并给出最佳实践的建议。
使用
lighthouse http://www.test.com
默认会在当前目录下生成一个HTM L格测评报告。TreeShaking即掩树优化意思是从包中删除所有引入但没有被实际用到的代码 ( 也
称为死代码Dead Code ) 来缩减打包后的体积。形象比喻为将‘废树叶’摇下来,是DCE( dead code elimination) 代码清除技术的一种。
Tree Shaking由来:
当javascript应用体积越来越大时,一个有利 于 减 少 体 积 的 办 法 是 拆 分 为 不 同 的 可 重用模块,如CommonJs、AMD、CMD模块化方案。
随着模块化的发展 ,开发人员还想进一步的移除多余的代码 , ES6模块的出现使 其成为可 能 , 打包工具Rollup团队率先提出并实现了Tree Shaking, Webpack 2.0版开始接入 , 至今不少打包工具都支持TreeShaking。
Tree Shaking 原理:
ES6模块静态化和静态分析是Tree shaking的基础。
静态分析就是不执行代码,在编译时从字面量上对代码进行分析从而正确判断到底加载了哪些模块 。 再分析程序流 , 判断哪些变量未被使用引用,进而删除对应代码。
早先CommonJS是动态require一个模块 , 可以嵌套在函数和if语句中 ,只有代码执行后才知道是否需要该模块 ,很难在译阶段通过静态分析去做优化。
ES6模块使用静态导入语法import , 且只能作为模块顶层的语句出现,这种静态化
在编译阶段就可以高度确定模块间的依赖关系 , 不依赖代码的运行结果 , 所以可以进行可靠的静态分析。
在webpa ck中由webpa ck通过静态分析标记出模块导出值中哪些没有被用过 , 然 后利用插件uglify(代码压缩优化工具)进行清除,删掉这些没被用到的方法。
在Webpack中使用Tree Shaking:
预加载就是将所有所需的资源提前请求加载到本地,这样后面在需要用到时就直接
从缓存取资源。
如果请求的内容过于庞大,没有使用预加载的页面就会长时间的展现为一片空白,使用预加载则可以减少等待的时间,拥有更好的体验。
指因为各种原因后端接口无法提供数据(如接口出错,依赖库出现问题,流量高峰挂了,断电断网等),前端依然能保证页面信息的正常展示。
主要方式是提前将数据存储在可靠的地方,在需要时能够高效便捷地获取到数据展示。通常有:
Localstorage
将数据存到Localstorage,通常接口路径作为key,返回数据作为value。若请求接口失败, 就读取L o c a l st orage ,将之前的数据取出来展示,并提示错误信息,以缓冲时间。
CDN容灾
除了 Localstorage同时也备份一份静态数据到CDN,在接口请求和Localstorage都没 有数据的情况下,从CDN获取备份数据。
Service Worker
可以利用Service Worker离线存储保个html页面。