2014-11-23 152 views
0

我想将一个变量作为参数传递给使用JQuery追加的onClick函数。由于行数不确定,我使用$ .each在每行的末尾添加一个按钮,单击它时会编辑该行。 所以要获得该行,我将该行的id传递给按钮中的Onclick函数,因为函数无法正常工作,所以我对引号感到困惑。将变量作为参数传递给onclick函数在.append中使用双引号和单引号JQuery

下面是代码

$.each(result, function (key, item) { 
       $("#table1").append("<tr><td>" + item.id + "</td><td>" + item.name + "</td> <td>" + item.type + "</td> <td>" + item.weight + "</td> <td>" + item.birthday + "</td> <td>" + item.hasHorns + "</td><td><input class='editR' id='" + item.id + "' type='button' value='EDIT' onclick='editRow('" + item.id + "')'/> </td> </tr>"); 
      }); 

功能

function editRow(eid) { 

    $("#table1").empty(); 
    //var eid = $(this).attr("id"); 
    alert(this); 
    $.getJSON(uri + "GetByID/" + eid, function (data) { 
     $("#headerType").replaceWith("<h2>Edit Animal</h2>"); 
     $("#table1").append("<tr><td><h4>ID</h4></td> <td><h4>Name</h4></td> <td><h4>Type</h4></td> <td><h4>Weight</h4></td> <td><h4>Birthday</h4></td> <td><h4>Has Horns</h4></td></tr>"); 
     $("#table1").append("<tr><td>" + data.id + "</td><td>" + data.name + "</td> <td>" + data.type + "</td> <td>" + data.weight + "</td> <td>" + data.birthday + "</td> <td>" + data.hasHorns + "</td> </tr>"); 
    }); 
} 

结果,对浏览器检查元素(对不起,因为它需要10 impoession我不能张贴图片)

<input class="editR" id="1" type="button" value="EDIT" onclick="editRow(" 1')'=""> 

一切正常,但点击上没有任何反应

谢谢

回答

2

尝试改用

onclick=\"editRow('" + item.id + "')\"/> 
+0

谢谢兄弟,就这么简单?有效 – Deeyo 2014-11-23 09:41:11

相关问题