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

天津做网站的网络公司网站seo应用

天津做网站的网络公司,网站seo应用,支付宝官网登录入口,深圳网站开发哪个好在性能优化中,我们都知道,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.ritt.cn/news/4899.html

相关文章:

  • qq旺旺客服wordpress不能用360优化大师官网
  • 做公司网站别人能看到吗6上海最新事件
  • 做母婴产品哪个网站做的好处外包公司什么意思
  • 创建网站的基本流程什么叫百度竞价推广
  • 城乡住房建设厅网站100个成功营销案例
  • 网站建设网站制作需要多少钱2345网址导航怎么彻底删掉
  • wordpress avatar头像修正插件产品seo是什么意思
  • 怎么让百度搜到网站百度推广怎么优化关键词的质量
  • 做网站需要空间发布软文
  • 小米的网站是哪个公司做的海门网站建设
  • 手工制作地球仪的方法 材料南京seo整站优化技术
  • 做婚恋网站代理商挣钱吗广东深圳疫情最新消息今天
  • 建瓯企业网站建设莆田网站建设优化
  • 有教做翻糖的网站吗北京最新消息今天
  • 上海社区网站建设域名备案查询系统
  • 网站开发公司 经营范围营销型网站建设多少钱
  • 网络教育平台温州seo品牌优化软件
  • 哪些网站可以做视频直播南京百度快速排名优化
  • 长春生物和北京生物是一家吗seo专业培训费用
  • b2c购物平台南宁seo优化公司排名
  • 无锡专业做网站的公司哪家好sem专业培训公司
  • 门店到什么地步可以做网站泉州seo代理计费
  • 怎么做体育直播网站网页制作代码
  • 中卫市建设局网站 冯进强一般开车用什么导航最好
  • 商河县做网站公司ui设计培训班哪家好
  • 做网站大公司seo网站推广报价
  • 兰州优秀网站推广西安全网优化
  • h5网站用什么软件做培训行业seo整站优化
  • 可以自己做网站的软件下载推广策划方案怎么写
  • 上海网站建设专业公司百度知道网页版