通过二次加载脚本,解决Ajax加载的页面中JS脚本不执行问题

本文探讨了在web开发中使用Ajax动态加载内容时遇到的Javascript执行失效的问题,并提出了解决方案,即把相关JS代码抽取到独立文件中加载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


场景:

web开发中,经常需要通过ajax动态加载网页(一般是通过ajax获取到网页内容,然后通过innerHTML等方式输出到页面上)。

比如:main.jsp存在多个页面区块,各个区块是采用ajax方式将内容加载到页面上。


问题:

main.jsp在加载inc1.jsp、inc2.jsp .....时,inc1.jsp中可能存在javascript代码,但这些代码被加载到main.jsp后往往无法有效执。


分析:

出于安全性考虑(可能是这样,未找到权威资料),浏览器禁止二次执行javascript脚本,所以被加载的网页脚本代码就无法被有效地执行。


解决方式:

将被加载页面(如inc1.jsp)中的javascript脚本代码抽取到一个脚本文件中(如:inc1.js),通过ajax成功加载后,再将对应的js脚本文件加载到本页面即可。关键代码如下:


var script = document.createElement("script");
script.src = "/inc.js";

var body = document.body;
body.insertBefore(script, body.firstChild);



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值