关于JSP中body标签中onload中函数不执行问题

问题描述:

  在一个页面中,我们经常会初始化一下数据,而且会在指定的DOM元素初始化数据,这时候我们就会使用<body onload="fun()">来加载我们的数据。onload指的是在所有的DOM元素都加载完成才会执行JS函数,这为我们初始化动态的加载数据提供很大的帮助。但是有时候我们会发现,<body onload="fun()">中的fun()函数有时候会不执行。下面分析一下onload不执行的原因和解决方法。

问题解决方案:

1.页面加载时就出现错误。

  这种是代码错误,可能是在加载DOM元素就报错,导致无法执行onload。这时候需要处理代码,查看代码哪里出错了。

2.页面一直在加载

  我们在浏览器的右下角会浏览器正在加载数据,有时间,由于网络原因(加载慢)或着找不到资源,然后页面就会一致加载,这时候onload可能就无法执行了。因为,onload是在加载所有DOM元素才会执行的。这时候也是处理代码,找到无法加载的资源,删掉或者找其他方式加载。

3.<body onload="fun()">body这个标签被覆盖、销毁(重点)

  在写JSP页面时,我们经常会用到类似于<jsp:include page="body.jsp"></jsp:include>来包含一个新页面。但是就在这时候,body.jsp是不会有<body>标签的,会被自动销毁。下面举个例子。

  这是main.jsp源代码

 <%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<html>
<head>
<title>onload不加载</title>
</head>
<body >
<p>这是主界面</p>
<jsp:include page="body.jsp"></jsp:include>
</body>
</html>

  这是body.jsp源代码

 <%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<html>
<head>
<title>body页面</title>
</head>
<body >
<p>这是body页面</p>
</body>
</html>

然后运行之后看效果,打开F12开发工具

关于JSP中<body onload="fun()">body标签中onload中函数不执行问题

我们只看见<p>标签,说明body.jsp的<body>标签被自动销毁。

  找到问题后就要想解决办法。其实我们发现,onload其实就是window.onload的另一种表现方式,原理都是一样的,这时候就使用window来实现加载数据了.

 <scripy type="text/javascrip">
function fun(){
alert("Hello World!");
} window.onload=function(){
fun();
}
</script>

这样在加载页面后执行fun()函数了,效果和<body onload="fun()">一样。

上一篇:源码编译安装MySQL 5.7.9


下一篇:C#读取Excel文件