首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用链接- jQuery的行和rel属性的id指向特定表行内容上的onclick事件

如何使用链接- jQuery的行和rel属性的id指向特定表行内容上的onclick事件
EN

Stack Overflow用户
提问于 2013-09-16 13:19:12
回答 3查看 923关注 0票数 1

我动态地生成了这个表

代码语言:javascript
运行
复制
<table>
    <tbody>
        <tr>
            <th>Email</th>
            <th>Name</th>
            <th>Date</th>
            <th>Action</th>
        </tr>
        <tr id="address-row-2">
            <td><input type="text" value="com@com.com" id="email-1" class="email"></td>
            <td><input type="text" value="John Doe 1" id="name-1" class="name"></td>
            <td>1 September 2013</td>
            <td><a href="#" class="orange" rel="edit-2">submit</a></td>
        </tr>
        <tr id="address-row-3">
            <td><input type="text" value="com@com.com" id="email-2" class="email"></td>
            <td><input type="text" value="John Doe 2" id="name-2" class="name"></td>
            <td>2 September 2013</td>
            <td><a href="#" class="orange" rel="edit-3>submit</a></td>
        </tr>
        <tr id="address-row-4">
            <td><input type="text" value="com@com.com" id="email-3" class="email"></td>
            <td><input type="text" value="John Doe 3" id="name-3" class="name"></td>
            <td>3 September 2013</td>
            <td><a href="#" class="orange" rel="edit-4>submit</a></td>
        </tr>
    </tbody>
</table>

submit按钮用于使输入可编辑,以更改内容内联。

代码语言:javascript
运行
复制
$("input.email:text, input.name:text").attr("disabled",true);
$(".orange").attr('href', 'javascript:void(0)').click(function (){
    $("input.email:text, input.name:text").addClass("show-border");
    $("input.email:text, input.name:text").removeAttr("disabled");
});

如何将按钮的onclick事件指向来自其行id的输入。更确切地说,如果我在第三行单击提交按钮,我希望只编辑来自第三行的输入。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-09-16 13:23:11

您需要遍历DOM以找到相对于单击按钮的元素。试试这个:

代码语言:javascript
运行
复制
$(".orange").attr('href', 'javascript:void(0)').click(function (){
    var $row = $(this).closest('tr');
    $("input.email, input.name", $row).addClass("show-border");
    $("input.email, input.name", $row).removeAttr("disabled");
});

Example fiddle

票数 0
EN

Stack Overflow用户

发布于 2013-09-16 13:22:27

只需使用closest在DOM中搜索:

代码语言:javascript
运行
复制
$('input').click(function(){
    var rowId = $(this).closest('tr').attr('id');
});

生活演示:http://jsfiddle.net/6uMjR/

票数 0
EN

Stack Overflow用户

发布于 2013-09-16 13:23:10

你可以:

代码语言:javascript
运行
复制
$(".orange").click(function() {
    $(this).siblings("input:text").prop("disabled", false);
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18829060

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档