首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

加载之——js 文件如何实现只加载执行

性能优化很常见的一个方式是提前加载文件,本文讨论如何在其他依赖未加载情况下提前加载一个.js文件。...1.导出一个函数 如果使用 加载一个js 文件,如果加载js 是一个自执行文件,那么会出现错误。...src="/test.js"> 使用标签会进行加载和执行,由于没有加载依赖函数bluer,控制台会出现以下问题: test.js:2 Uncaught...2.使用xhr 或者fetch 加载 可以使用xhr 或者 fetch 来获取js 文件,可以得到js 字符串,在需要获取的时候在使用eval方法进行调用,以下以fetch 为例,具体调用如下: fetch...使用preload 加载资源 preload 会强制浏览器立即获取资源,并且该请求具有较高的优先级。并且是在阻塞 document 的 onload 事件的情况下请求资源。具体是使用。

5.8K10
您找到你想要的搜索结果了吗?
是的
没有找到

Js文件异步加载

Js文件异步加载 浏览器中渲染引擎与Js脚本引擎是互斥的,在浏览器开始渲染页面时,如果遇到标签,会停止渲染当前页面,也就是说在脚本加载与执行的过程中会阻塞页面的渲染,在网速较差的环境下可能会出现浏览器页面假死的情况...,这也就是尽量将文件放置于后的原因,Js文件异步加载就是使浏览器加载外部Js脚本文件阻塞渲染线程,这称为非阻塞模式加载,当然加载完成之后解析执行Js脚本时必须与渲染引擎互斥...,解析执行Js脚本的时机取决于异步加载Js的方式。...defer defer是早期IE支持的属性,目前主流浏览器都已经支持。 defer只适用于外联脚本。 如果有多个声明了defer的脚本,则会按顺序下载和执行。..." > Script DOM Element Script DOM Element的方式即动态插入一个标签来加载外部Js脚本文件,将其作为onload事件的回调函数,即在页面加载完成后再执行

10.3K20

IEJS文件失效问题总结

今天遇到了一个很诡异的问题,Firefox下好好的页面,在IE下却接二连三的报错,这到底是什么地方产生的错误。  经过一上午的仔细排查,发现了真凶原来是IE对于对象和数组定义的严格限制。...在JS中,我们一般定义数组和对象都如下: var arr = [   arr1,   arr2,   arr3,   arr4 ]; 对象: var obj = {   param:one,...  param:two,   param:three }; 如果最后的一项多了一个“,”,那么在IE中就会产生错误,从而最终导致引用的JS文件失效。...例如: function a(){ ... } var obj = {   param:a,...,如果文件小函数少的时候比较容易发现,如果函数很多,而恰恰对象的定义放在文件末尾的话,那就比较痛苦了。

3.4K30

IE之页面加载慢.

结果在IE下发现加载异常缓慢, 还有部分人员反馈页面卡死. 后台读写优化 默认处理图片逻辑是, ImageIO读取原图, 转成byte[], base64编码后, 放到dom里....IE与Gzip 如果不是图片导致的加载慢, 为什么很多小伙伴反馈大屏慢呢? IE以及Edge似乎更卡一点.  我们用Chrome访问一张大屏模板, 对比下IE访问模板的响应时间....op=fs_main&cmd=entry_report&id=2571 截图一看清楚了, IE里看上去Gzip就没起作用, 实实在在的加载js. 用了4s才加载完....重复上述访问entry操作, 等得的快炸的时候, 页面终于加载出来了. 低速网络下, 两个js累计加载耗时561s!!! ...开启Gzip后, 跟Chrome速度一样了, 两个js累计114s, 越是低速网络, Gzip效果越明显.

2.3K70

前端 实战项目·动态加载 JS 文件

动态加载 JS 文件 对于 Vue、React 等框架开发的单页面应用,在某些页面开发特殊功能时经常需要依赖第三方 JS 文件,如果在全局引入 CDN 资源可能会加载冗余文件,此时最好使用动态加载方式...动态加载 JS 脚本指仅在某些特殊页面引入依赖文件,而非全局引入,这样可以避免在这些页面并未打开时造成加载无用的资源,提高页面加载速度的同时,也让整个项目更加模块化。... 元素也是如此,它与页面其他元素没有什么不同,所以可以手动创建 来加载 JS 文件。...都依赖 jquery,而 locale 依赖 fullcalendar,这种情况需要让 JS 文件按照一定的依赖关系按次序加载资源。...,但可以通过监听 onload 事件来判断文件是否加载完成,配合 Promise 等待上一个脚本文件加载完成后再加载下一个文件,从而实现按次序加载执行脚本。

5.1K40

js怎么动态加载js文件(JavaScript性能优化篇)转

下面介绍一种JS代码优化的一个小技巧,通过动态加载引入js外部文件来提高网页加载速度 【基本优化】 将所有需要的标签都放在之前,确保脚本执行之前完成页面渲染而不会造成页面堵塞问题...【合并JS代码,尽可能少的使用script标签】 最常见的方式就是带代码写入一个js文件中,让页面只使用一次标签来引入 ? 3....【无堵塞加载JS】 通过给script标签增加 defer属性或者是 async 属性来实现 注解: async...'), fn = callback || function(){}; script.type = 'text/javascript'; //IE...该原理实现的也有很多不错的js类库可以使用,如LazyLoad.js,支持数组的形式引入,打开浏览器在network中可看到js是同步加载的 ? ? 7.

19.2K12

解决IE响应式的解决方案css3-mediaqueries.js生效问题

前阵子解决了博客在低版本 IE 下会假死的问题,发现居然是因为我自定义 CSS 的闭合误用了中文大括号导致的! 解决这个问题之后,又发现了另外一个坑:发现博客在 IE8 及以下版本的响应式生效。...--[if lt IE 9]> <script...苦逼重复的替换了几次 js 文件、刷新各种缓存,硬是没有解决! 没办法了,看来还得求助搜索引擎了。最终,发现居然因为这个 js 不支持跨域(文章忘记收藏了)!...原来,不支持跨域不是说这个 js,而是指含有响应式代码的 CSS 文件!...将 style.css 中响应式写法的 css 代码全部复制一份,放到额外的一个 css 文件中,然后使用和网站相同域名,引入到 head 部分的 IE 判断语句中即可!

2.5K90
领券