加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 教程 > 正文

js函数名和form表单元素同名冲突的问题

发布时间:2023-10-24 15:15:58 所属栏目:教程 来源:
导读:今天在导出Excel的时候用了Form 表单的input hidden 来区分导出和搜索。开始的时候js中的onClick事件的函数名 和 hidden 中的 id 命名一样。结果导致报错:调用函数的那一行对象不支持此属性。

找了很长时间都找
今天在导出Excel的时候用了Form 表单的input hidden 来区分导出和搜索。开始的时候js中的onClick事件的函数名 和 hidden 中的 id 命名一样。结果导致报错:调用函数的那一行对象不支持此属性。
 
找了很长时间都找不出原因,开始的时候一直以为是写错了某个字母,才发现js函数根本没有执行。后来没有办法直接调用了别的函数,发现就有用了,认为是函数名的原因,改了函数名才有用了。然后再将input中的id改成很函数名一样,又出现报错了。在没有下例验证之前,还一直以为是ThinkPHP模板解析的bug。因为有了如下示例,所以证实是js中的函数名不可以和元素中的id相同。
 
如下例:
 
代码如下:
 
<html>
 
<head>
 
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
 
<title>ceshi</title>
 
<script>
 
function a()
 
{
 
 document.getElementById('a').value="test";
 
 alert(document.getElementById('a').value);
 
 return false;
 
}
 
</script>
 
</head>
 
<body>
 
<form>
 
<input type="hidden" id="a" name="a" value="" />
 
<input type="button" value="excel" onClick="javascript:a();"/>
 
</form>
 
</body>
 
</html>
 
网页错误详细信息
 
用户代理: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; CIBA; .NET CLR 2.0.50727)
 
时间戳: Thu, 27 Jan 2011 13:30:09 UTC
 
消息: 对象不支持此属性或方法
 
行: 17
 
字符: 1
 
代码: 0
 
URI: file:///C:/Documents%20and%20Settings/Administrator/桌面/test.html
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章