Javascript 将变量传递给 onclick 不起作用

标签 javascript html javascript-objects

我正在尝试使用 Javascript 通过 HTML 生成将变量传递给另一个函数,但它没有通过。这是我的代码:

var wer_people_btn1 = document.createElement("span");
wer_people_btn1.setAttribute('onclick', 'SendData(' + user.ID + " ANDINFO " + susData + ')');

function SendData(reply) {
}

user.ID contains "3323"

susData contains "< DATA > (info_user)"

我得到的错误:

Uncaught SyntaxError: missing ) after argument list

我认为 <> 括号在这里造成了麻烦。如何将它们作为字符串传递给我的函数?

最佳答案

因为无论你发送什么,数据都必须是一个字符串。所以字符串必须在引号 '" 中,但它不应该冲突。所以使用 Javascript 的单引号和双引号,或者通过使用转义字符尝试只使用一个\'

wer_people_btn1.setAttribute('onclick', "SendData('" + user.ID + " ANDINFO " + susData + "')");

如评论中所述,只能传递event和element(this)。

更好的解决方法:上面将为 SendData 创建单个字符串输入,但您希望作为单独的参数接收,那么下面的方法有效 "SendData("+ user.ID + ",'"+ susData + "')"); 其中 SendData 的函数原型(prototype)是 SendData(userId, susData) //user.ID 没有引号,因为它是一个数字

如果需要传递自定义对象,那就看这个SO 1st answer ,这些是我所知道的唯一可能的方法。

关于Javascript 将变量传递给 onclick 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32672711/

相关文章:

html - 模型驱动形式 : validation not working as expected in Angular 2

javascript - Youtube iFrame API 将数据从 onYouTubeIframeAPIReady 传递到 onPlayerStateChange 函数

javascript - array.sort() 没有给出所需的结果

javascript - 从 HTTP 函数将图像文件写入 Firebase Storage

jquery - IFrame 替代品

javascript - 在构造函数中的独立函数内访问 'this'

javascript - react 数组中的计数对象属性

javascript - 错误 : Cannot find module 'wrench' , 当我运行 gulp 命令时出现此错误

javascript - 如何为这个原型(prototype)创建一个界面?

javascript - 使用 xoxco 在搜索框的焦点上下拉 div