js拼的onclick调用方法需要注意的地方 之一
1.首先,明确一点,js方法中参数可以传递字符串,对象,number类型等,对象传递的是引用,方法中修改了,会影响到方法外面的对象。
2.下面重现项目中遇到的一个问题:(其实就是要明白通过引号来拼接字符串时的问题)
有一个通用的js方法如下:
//邮件催送 sendTcMail = function(obj) { //异步请求查询级联子列表的方法并返回json数组 jQuery.ajax({ url : cur_url+"/tapeoutCheck/mailReminder", type : 'post', data : JSON.stringify(obj), dataType : 'json', contentType:'application/json;charset=utf-8', success : function (data, textStatus) { if (data.success == 1) { $.gritter.add({ title: '提示', text: '操作成功.'+data.message, class_name: 'success' }); } if (data.success == 2) { $.gritter.add({ title: '提示', text: '操作失败.'+data.message, class_name: 'danger' }); } }, error: function (XMLHttpRequest, textStatus) { $.gritter.add({ title: '提示', text: '邮件催送失败.', class_name: 'danger' }); } }); }
方法参数需要一个json对象,然后通过JSON.stringify(obj)方法转换为json字符串,传递到后台。
(1)。直接在jsp中onclick方法调用该方法:
<a href="javascript:void(0);" onclick="sendTcMail({'projectId':223,'projectName':'abc'})">test</a>
这样是最简单的,方法中直接传递json对象就可以了。
(2)第二种方法。
如下,有一个div,通过js动态拼接了一个a标签放到div中,a标签中拼出来onclick中的方法:
<div id="test"></div> $(function() { getA = function(){ var a = '<a href="javascript:void(0);" onclick="sendTcMail({\'projectId\':223,\'projectName\':\'abc\'})">test</a>'; $('#test').html(a); } getA(); })
这getA方法中通过字符串拼接出了A标签,里面onclick中方法参数其实和第一种是一样的,不过外层有一个单引号,所有参数的单引号进行了转义。这种和第一种是一样,传递的也是json对象
(3)这种是第二种的衍生,需要特别注意,这次onclick中参数是通过变量传递进去的
getA = function(){ var obj = {'projectId':123,'projectName':'aac'}; var a = '<a href="javascript:void(0);" onclick="sendTcMail(obj)">test</a>'; $('#test').html(a); }
如果是这样写的,会报错obj未定义,因为a是字符串,obj不是用的上面的var obj变量,所以js解析器不认识obj。
getA = function(){ var obj = {'projectId':123,'projectName':'aac'}; var a = '<a href="javascript:void(0);" onclick="sendTcMail(\'obj\')">test</a>'; $('#test').html(a); }
如果是这样,那'obj'就是字符串传递到方法中的,不是用的var的那个obj对象。也不行。
getA = function(){ var obj = {'projectId':123,'projectName':'aac'}; var a = '<a href="javascript:void(0);" onclick="sendTcMail('+obj+')">test</a>'; $('#test').html(a); }
很多人肯定会这样拼接自己定义的obj 对象变量,但是这样也是不可以的,这个obj变量拼在字符串中是一个对象引用,并不是{'projectId':123,'projectName':'aac'},拼出来方法会变成这样的sendTcMail([object Object]),会报错的,这种错误是最常见的,这是这篇博客的重点,要知道这错误的原因。
如果只是传递obj对象中的projectId属性可以这样拼接:
getA = function(){ var obj = {'projectId':123,'projectName':'aac'}; var a = '<a href="javascript:void(0);" onclick="sendTcMail('+obj.projectId+')">test</a>'; $('#test').html(a); }
这传递到方法中的就是obj的projectId属性值123,这是可以的。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧