首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用jQuery操控td

使用jQuery操控td
EN

Stack Overflow用户
提问于 2011-03-22 17:58:59
回答 3查看 90关注 0票数 0

我有下面的html结构。

代码语言:javascript
复制
<td class="coll-1">
   <b><a href="#">Some link text</a></b>
   <p>Description lorem ipsum dolor sit amet consect</p>
</td>

我想用jQuery做一些类似的东西。我不能修改代码,所以必须使用这个。

代码语言:javascript
复制
<td class="coll-1">
   <div class="col-1-data">
     <b><a href="#">Some link text</a></b>
     <p>Description lorem ipsum dolor sit amet consect</p>
   </div>
</td>

请按需要做

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-03-22 18:06:21

使用jQuery,您可以使用wrapInner函数执行以下操作。

代码语言:javascript
复制
$(".coll-1").wrapInner("<div class='col-1-data' />");
票数 3
EN

Stack Overflow用户

发布于 2011-03-22 18:03:31

您可以使用wrapAll

代码语言:javascript
复制
$("td.coll-1 *").wrapAll('<div class="col-1-data" />');

编辑:由于一些评论,它是有效的:jsFiddle

票数 6
EN

Stack Overflow用户

发布于 2011-03-22 20:24:46

我个人会同意felixsigl上面的答案,但看到你的<TD>是有编号的,我假设这些都是编号的,并在你的页面上重复,如果是这样的话,我们将不得不在他的答案上做更多的工作。

以下代码:

  1. 使用指定的<DIV>元素包装<TD>的子类,而
  2. 为与父数据的类相对应的<DIV>分配一个编号类。(即coll-2 => col-2-data)

代码:

代码语言:javascript
复制
    $('td[class^="coll-"]').each(function() {

        var el = $(this);
        var num = el.attr('class').split('-')[1];

        el.children().wrapAll('<div class="col-'+num+'-data" />');

    });

我会看看我能做些什么来简化它,但这目前工作得很好。updated jsFiddle

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5389467

复制
相关文章

相似问题

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