js中在window.onload写一个函数为什么在dom节点中不能调用,会报错。代码如下
!DOCTYPEhtml><html><head><metacharset="UTF-8"><title></title><scripttype="text/javasc...
!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
window.onload = function(){
function inset()
{
console.log("ok");
}
}
</script>
</head>
<body>
<button onclick="insert()">test</button>
</body>
</html>
error:Uncaught ReferenceError: insert is not defined
调用时的函数名写错了,改过来这个问题还是会存在的 展开
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
window.onload = function(){
function inset()
{
console.log("ok");
}
}
</script>
</head>
<body>
<button onclick="insert()">test</button>
</body>
</html>
error:Uncaught ReferenceError: insert is not defined
调用时的函数名写错了,改过来这个问题还是会存在的 展开
1个回答
展开全部
你在js中定义的是inset,在butto写的是insert,字母都拼错了
下面是我修改的代码,去掉了一些不必要的东西,Window.onload不要乱用,只需要定义一个function,在元素里面调用就行了。。
!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
function inset()
{
console.log("ok");
}
</script>
</head>
<body>
<button onclick="inset()">test</button>
</body>
</html>
下面是我修改的代码,去掉了一些不必要的东西,Window.onload不要乱用,只需要定义一个function,在元素里面调用就行了。。
!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
function inset()
{
console.log("ok");
}
</script>
</head>
<body>
<button onclick="inset()">test</button>
</body>
</html>
更多追问追答
追问
这样我知道可以,我就是想不明白为什么onload里面为什么会出问题?
追答
window.onload就表示你打开网页就会自动执行这段代码,但是你的需求是在button里面调用的,而不是打开网站就执行的,所以逻辑上就已经错了,应该单独定义一个function,在点击的时候调用即可
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询