关于jquery的load()同步阻塞


现在要在一个主页面中分别加载页头和页尾,用iframe性能不好,纯html页面所以也不能用php的include方法直接加载页面,React、angular这些框架的模板导入我也还没学过,所以想来想去只能jquery的load()加载进来,现在的问题是load方法会造成同步的主线程阻塞问题,页面体验很不好。

Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to the end user's experience. For more help, check https://xhr.spec.whatwg.org/.

现在我的问题是:
1.load方法不能像.get或.post这些ajax方法一样设置成异步加载,从而避免阻塞主线程吗?我要怎么解决load()造成的主线程阻塞问题?
看过相关资料,用h5的Worker好像可以避免主线程阻塞,是不是只有这种方式能解决,worker没用过。

2.针对我这种需求,除了我文中说的这几种方式外,就目前我的情况来说应该怎么解决,公司开发中哪种方式解决页头页尾加载最好呢?

欢迎大家的帮忙解决,谢谢!


繁华开满天机
浏览 468回答 1
1回答

扬帆大鱼

load()默认就是异步加载的,不会造成主线程阻塞。所以警告中的同步阻塞问题不是这里单一的load()造成的。我后来查了子页面,发现子页面中有<script src="*">,。于是去掉了子页面中的外部js引入,警告就没有了。所以是load()和子页面中的外部js引入造成的同步阻塞警告。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript