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

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

阅读 11k
3 个回答

load()默认就是异步加载的,不会造成主线程阻塞。所以警告中的同步阻塞问题不是这里单一的load()造成的。我后来查了子页面,发现子页面中有<script src="*">,。于是去掉了子页面中的外部js引入,警告就没有了。所以是load()和子页面中的外部js引入造成的同步阻塞警告。

1.此方法的底层调用的是$.ajax()方法,对服务端进行ajax请求。所以默认就是异步加载的,不会造成主线程阻塞。
。不过因为默认就是异步加载,所以就可能出现这种情况,页面主体部分先显示出来,而后服务端的页头,页尾数据才返回过来并插入页面中,导致页面主体部分,页头,页尾不同时出现,会闪一下。
2.我遇到的情况是页头页尾搭配相对固定的情况,因此可以做一个模板页面,页头和页尾写死在其中,而后页面的主体部分嵌入iframe,根据情况设置iframe的地址指向相应的具体页面。

1当然可以.

var html = $.get('xx.yy');
$('selector').html(html);

2.我一般是头和尾,加上content,会做成base.html,php用的时候会extend base.html
就像这样

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题