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

网站设计网页版营口市城乡住房建设局网站

网站设计网页版,营口市城乡住房建设局网站,公司网站制作仿站,软件定制化开发在性能优化中,我们都知道,async属性可以让script标签变得不阻塞HTML解析,defer属性也有类似的功能,但实际defer是会阻塞script解析的(用defer的话,多个script会按顺序执行,而async执行是无序的&…

在性能优化中,我们都知道,async属性可以让script标签变得不阻塞HTML解析,defer属性也有类似的功能,但实际defer是会阻塞script解析的(用defer的话,多个script会按顺序执行,而async执行是无序的,谁下载的快执行谁),使用async属性理论上讲,是要比defer更快的。

用async属性有什么问题?

感觉不太安全,因为async会让多个script标签执行是无序的

实际测试async,看看是否是危险的

随便用一个脚手架起项目(vuereact都行),build之后,进入dist目录下,用http-server起服务,访问html如下(手动改成async)。

<!doctype html>
<html lang="">
<head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,initial-scale=1"><link rel="icon" href="/favicon.ico"><title>hello-world</title><script async src="/js/chunk-vendors.f5ba3c0d.js"></script><script async src="/js/app.382b3f67.js"></script><link href="/css/app.2cf79ad6.css" rel="stylesheet">
</head>
<body><div id="app"></div>
</body>
</html>

用弱网访问,看下的图,很明显 app.382b3f67.js 要先下载完(因为size小)。

确认是否是 app.382b3f67.js 先执行, 手动往2个js里面埋入log代码,结果和预期一样,app.382b3f67.js先执行

确认 chunk-vendors.f5ba3c0d.js 里面的代码是关键依赖,比如是vuereact,理论上讲,应该是要报错的,因为依赖后执行了,但结果并没有报错。

结论

webpack项目内,可以放心对多个script标签使用async属性,webpack已经对产物做好了兼容

webpack是如何实现兼容async的?

分析打包出来的产物,可以探知到webpack是如何实现的

产物1app.382b3f67.js (简化后的,方便理解)。

(function () {"use strict";var __webpack_modules__ = ({4629:(function (__unused_webpack_module, __unused_webpack___webpack_exports__, __webpack_require__) {}),6949:(function (module) {})});!function () {// ...var chunkLoadingGlobal = self["webpackChunkhello_world"] = self["webpackChunkhello_world"] || [];chunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));// .push 被改写chunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));}();var __webpack_exports__ = __webpack_require__.O(undefined, [998], function () {return __webpack_require__(4629);})__webpack_exports__ = __webpack_require__.O(__webpack_exports__);
})();
console.log('app.382b3f67.js')

产物2chunk-vendors.f5ba3c0d.js(简化后的,方便理解)。​​​​​​​

(self["webpackChunkhello_world"] = self["webpackChunkhello_world"] || []).push([[998], {// ...
}]);
console.log('chunk-vendors.f5ba3c0d.js')

解释:

  • 1、app.382b3f67.js里面的关键代码(webpack打包时的入口代码index.js),比如new Vue()root.render(),被存放到了__webpack_require__(4629)里面(每次打包数字会变,不一定是4629)

  • 2、4629 没有立即被执行,而是先存放好,等依赖[998]准备好,才执行

那app.382b3f67.js怎么知道依赖998已经准备好了呢?

  • 1、依赖[998]就是chunk-vendors.f5ba3c0d.js,998被 .push 到了 self["webpackChunkhello_world"] 里面,这个push不是Array.push,而是被改写过的(我在上面写了注释,具体是哪一行被改写了)

  • 2、改写的作用是:可以通知到 app.382b3f67.js,998依赖已经准备好了

由此可以得到结论:

  • 依赖未准备好时,webpack打包时的入口代码index.js不会执行。

  • 到这里还没完,由上面的结论可以发现:如果不做特殊处理,我们几乎无法监控到webpack应用的白屏问题。

因为如果某个js资源网络问题丢失了,index.js根本就不会执行,意味着上报代码也不会执行。如果js执行报错,那直接进程退出了,上报代码也不会执行(除非try catch了)。

学习上

作为一个软件测试的过来人,我想尽自己最大的努力,帮助每一个伙伴都能顺利找到工作。所以我整理了下面这份资源,现在免费分享给大家,有需要的小伙伴可以关注【公众号:开心螺蛳粉】自提!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。在这里插入图片描述

在这里插入图片描述

行动吧,在路上总比一直观望的要好,未来的你肯定会感谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入群:1150305204,里面有各种测试开发资料和技术可以一起交流哦。

http://www.yayakq.cn/news/587091/

相关文章:

  • 紫色网站岳麓区营销型网站建设定制
  • 做产品封面的网站扫码进入网站如何做
  • 宁波网站seo公司铜陵网站制作公司
  • 系部网站建设中期检查表网页制作工具软件下载
  • 广州市网站建设 骏域动力西安个人做网站
  • 迪拜哪个网站是做网站的杭州做网站排名软件
  • 网站建设算入会计分录系统ui设计界面
  • 展示型企业网站营销目标主要有网站运维推广怎么做
  • 网站 短链接怎么做织梦dedecms网站内容页
  • 中小学生在线做试卷的网站眯眯扑克app哪个公司开发
  • 一流学科建设专题网站泉州网红餐厅
  • 免费做网站收录的先做网站还是先注册公司
  • 网站中的文章可以做排名吗wordpress 修改权限
  • 网站后台的seo功能怎么学电商从零开始
  • 成都哪家做网站的最好做网站克隆
  • 网站建设吉金手指排名15小清新文章网站
  • 安徽房地产网站建设技术社区网站开发例子
  • 如何更换网站服务器网站开发维护前景
  • iis发布域名网站电影院订票网站开发
  • 做网站多少钱zwnet沈阳市建设工程质量检测中心网站
  • 网站建设工作是干什么的做网站的优点
  • 厦门商场网站建设网站前端培训
  • 公司网站后台怎么上传视频工信部网站备案被注销
  • 做本地地旅游网站龙岩网站排名
  • 个人免费注册公司网站网站建设与管理 期末
  • 怎么查有做网站的公司互联网的营销推广方式
  • 北京工程工程建设交易信息网站汕头市建设工程交易网
  • 在网站上做的h5如何发到微信上网站职业培训机构
  • 深圳网站建设找哪网站建设架构
  • 建设网站需要申请什么软文写作公司