首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何选择$(this) children div?

如何选择$(this) children div?
EN

Stack Overflow用户
提问于 2011-01-27 21:23:02
回答 3查看 1.6K关注 0票数 1

这是一篇AJAX文章。有一组按钮,我在每个按钮后面添加一个div#message。

我希望当用户单击每个按钮时,单词hello将显示在每个div#message中。如何在div#message‘前添加$(this)?

JS:

代码语言:javascript
复制
success: function(){
    $('#message').fadeIn(1000, function() {
        $('#message').html("hello");
    })
    $('#message').fadeOut(1000, function() {
        $('#message').html('');
    })

CSS:

代码语言:javascript
复制
#message{display:none;float:right}

HTML:

代码语言:javascript
复制
<div class='post'><a href="" class="ajaxpost" id="'.row['id'].'" name="ajaxpost">'.row['title'].'</a><div id="message"></div></div>
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-01-27 21:25:07

你可以写

代码语言:javascript
复制
$(this).children('div#message')

如果您还想搜索子对象,请调用find而不是children

然而,它实际上不会起作用。

success回调中,this不会引用您的元素。

您可以通过在AJAX参数中传递context: this,或者将外部函数中的一个变量设置为this并使用该变量来更改它。

但是,您一开始就不应该这样做。

ID应该是唯一的。

如果在不同的块中有多个div#message,则应该使用class而不是id

票数 2
EN

Stack Overflow用户

发布于 2011-01-27 21:25:52

添加具有相同ID的多个div不是一个好主意。请改用类。

您可以执行以下查询:

$('.message',this).fadeIn(...

票数 0
EN

Stack Overflow用户

发布于 2012-12-06 01:59:22

在我的例子中,children(...)不能正常工作。

如果您还想搜索子对象,请调用

而不是子对象。

因此,在我的例子中,只有find(.class_name)可以正常工作

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

https://stackoverflow.com/questions/4816843

复制
相关文章

相似问题

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