通过二次加载脚本,解决Ajax加载的页面中JS脚本不执行问题
2013-10-21 16:03
676 查看
场景:
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);
相关文章推荐
- Ajax中主页加载分页面后,分页面js脚本不执行的解决办法
- Ajax中主页加载分页面后,分页面js脚本不执行的解决办法
- JQuery 解决用load加载页面到div时,不执行页面js的问题
- 解决用jquery load加载页面到div时,不执行页面js的问题
- 解决用jquery load加载页面到div时,不执行页面js的问题
- 解决ajax加载的页面js无法找到的问题
- 解决用jquery load加载页面到div时,不执行页面js的问题
- Easyui添加tab时以href形式载入页面 未执行js脚本问题解决
- JQuery 解决用load加载页面到div时,不执行页面js的问题
- dwzjs在firefox下遇到页面加载问题解决方法
- 使用加载图片解决在Ajax数据加载中页面出现短暂空白的问题(推荐)
- vue.js 部署到tomcat中出现访问路径不对,页面加载不出来问题及解决
- EasyUI的window加载的页面不执行js问题说明
- 利用ajax在index页面自动执行方法并显示相关内容,在执行相关按钮操作(如登录注册)后返回index页面后ajax不执行,无法显示相关内容的问题解决方法之一
- 动态加载JS文件,完美解决跨域、编码、嵌套、队列、兼容性、执行顺序等相关问题。
- EasyUI的window加载的页面不执行js问题说明
- EasyUI 关于 panel,window,dialog 通过href加载页面,页面中引用的js不执行的解决方案
- 37-002-1 通过spring的OpenSessionInViewFilter解决jsp页面懒加载显示的问题
- dijit.layout.ContentPane href加载页面后,被加载页脚本不执行的解决办法
- jQuery EasyUI动态添加控件或者ajax加载页面后不能自动渲染问题的解决方法