0

我使用jTemplates插件在我的表上加载数据。因为有些属性我还没有显示,但我希望以后可以使用,我将它们保存在隐藏字段中,然后通过它们的 CSS 的类名和 jQuery 的siblings方法来获取它们。

这是进行此类操作的正确方法,还是会被认为是糟糕的代码?

<script type="text/javascript">
$(function() {
    $("#edit").click(function(e) {
        e.preventDefault();
        var $this = $(this);

        var date = {
            Id:        $this.siblings(".tid").val(),
            StartDate: $this.siblings(".tdate1").val(),
            EndDate:   $this.siblings(".tdate2").val(),
            ClientId:  $this.siblings(".tclient").val(),
            UserId:    $this.siblings(".tuser").val()
        };

        processDate(date);
    });
});
</script>

<textarea id="template" class="ui-helper-hidden">
<table id="dates">
    <thead>
        <tr>
            <th>Id</th>
            <th>Start Date</th>
            <th>End Date</th>
            <th>Client</th>
            <th></th>
       </tr>
    </thead>
    <tbody>
        {#foreach $T as record}
            <tr>
                <td>{ $T.record.Id }</td>
                <td>{ formatDate($T.record.StartDate) }</td>
                <td>{ formatDate($T.record.EndDate) }</td>
                <td>{ $T.record.Client.Name }</td>
                <td>
                    <button id="edit">Edit</button>
                    <input type="hidden" class="tid"        value='{ $T.record.Id }' />
                    <input type="hidden" class="tdate1"     value='{ $T.record.StartDate }' />
                    <input type="hidden" class="tdate2"     value='{ $T.record.EndDate }' />
                    <input type="hidden" class="tclient"    value='{ $T.record.Client.Id }' />
                    <input type="hidden" class="tuser"    value='{ $T.record.User.Id }' />
                </td>
            </tr>
        {#/for}
    </tbody>
</table>
</textarea>

建议将被欣然接受。:)

4

3 回答 3

2

你有什么作品,虽然你也可以使用这样的数据属性

    {#foreach $T as record}
        <tr data-tid="{ $T.record.Id }" data-tdate1="{ $T.record.StartDate }" data-tdate2="{ $T.record.EndDate }" data-tclient="{ $T.record.Client.Id }" data-tuser="{ $T.record.User.Id }">
            <td>{ $T.record.Id }</td>
            <td>{ formatDate($T.record.StartDate) }</td>
            <td>{ formatDate($T.record.EndDate) }</td>
            <td>{ $T.record.Client.Name }</td>
            <td>
                <button class="edit">Edit</button>
            </td>
        </tr>
    {#/for}

然后例如在单击编辑按钮时获取属性:

$(".edit").click(function() {
  var user = $(this).closest("tr").attr("data-tuser");
  //do something...
});

请注意对编辑按钮的更改...您应该在此处使用类而不是 ID,因为它是重复的。

附带说明一下,由于主分支最近发生了变化,在jQuery 1.5中,您将能够.data("tuser")代替.attr("data-tuser").

于 2010-09-21T13:20:15.397 回答
0

恕我直言,当您从服务器生成数据时,这是一种完全可以接受的存储数据的方式。data-另一种选择是在表格行上生成属性。两者都是存储数据的有效方法,后者可能稍好一些。

于 2010-09-21T13:20:37.160 回答
0

正如我所看到的,如果它有效,那么像你描述的那样微不足道的功能就可以了。至于将您的值保存在隐藏字段中 - 这可以更优化地完成。您可以尝试将值保存到变量中。然后检索它们会更简单,您不必遍历 DOM 来检索它们。

于 2010-09-21T13:33:53.677 回答