选择 td 内的元素

发布于 2024-09-18 10:02:55 字数 772 浏览 10 评论 0原文

我有以下 jQuery 代码来突出显示表格单元格。

这是我的 html:

<table>
   <tr>
        <td class="day">
             <span class='hiddenImage'><img src='/images/test.png' /></span>
        </td>
        <td class="day"><span class='hiddenImage'><img src='/images/test.png' /></span>
        </td>
   </tr>
</table>

这是我的 jquery 代码

$("td").hover(
    function () {
          [show image]
    },
    function () {
          [hide image]
    }
);

在表格单元格内,我有一个隐藏的 ,其类名为 hiddenImage。当我将鼠标悬停在该 td 单元格上时如何显示图像?

函数内部有类似的东西(但下面的似乎不起作用)

 $(this '.hiddenImage').show();

I have the following jQuery code to highlight table cells.

Here is my html:

<table>
   <tr>
        <td class="day">
             <span class='hiddenImage'><img src='/images/test.png' /></span>
        </td>
        <td class="day"><span class='hiddenImage'><img src='/images/test.png' /></span>
        </td>
   </tr>
</table>

here is my jquery code

$("td").hover(
    function () {
          [show image]
    },
    function () {
          [hide image]
    }
);

Inside the table cell, i have a hidden <span> with class name hiddenImage. How do I display the image when i am hovering over that td cell?

Something like this inside the functions (but the below doesn't seem to work)

 $(this '.hiddenImage').show();

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

記憶穿過時間隧道 2024-09-25 10:02:55

我会在 CSS 中执行此操作,规则是搭载您已经使用的 .hover 类,如下所示:

td.hover .hiddenImage { display: inline-block; }

那么您的 jQuery 也更简单:

$("td").hover(function() {
  $(this).toggleClass("hover");
});

或者,如果您不关心 IE6然后完全在CSS中完成(根本没有脚本):

td:hover { ...styling... }
td:hover .hiddenImage { display: inline-block; }

或者如果您必须在jQuery中(尽管它太过分了),请使用.find() 获取其中的元素,如下所示:

$("td").hover(function () {
  $(this).toggleClass("hover").find(".hiddenImage").toggle();
});

I would do it in CSS with a rule that piggbacks on the .hover class you're already using, like this:

td.hover .hiddenImage { display: inline-block; }

Then your jQuery is simpler as well:

$("td").hover(function() {
  $(this).toggleClass("hover");
});

Or, if you don't care about IE6 then just do it completely in CSS (no script at all):

td:hover { ...styling... }
td:hover .hiddenImage { display: inline-block; }

Or if you must in jQuery (though it's overkill), use .find() to get an element within, like this:

$("td").hover(function () {
  $(this).toggleClass("hover").find(".hiddenImage").toggle();
});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文