jQuery find() 只对 AJAX 结果起作用一次?

标签 jquery ajax

我是 jQuery 新手,在使用 jQuery 方法操作 AJAX 结果时遇到了一些问题。

我使用 AJAX get 并对结果输出执行 find 方法。但这似乎只起作用一次。在 find() 参数中使用相同选择器的后续尝试不起作用。不同的选择器都可以工作,但同样,只能工作一次。

遍历AJAX结果的时候好像出了什么问题?

AJAX 调用...

    $.get('sections.htm', {}, function(data) {
        var $response = $('<div />').html(data);
        showContent("teaser");

        function showContent(nav) {
            loadContent(nav);
            loadSlimboxHack();
            $('#content').fadeIn(400);
        }

查找元素...

    function loadContent(nav) {
        if (nav == 'teaser')
        {
            $('#content').html($response.find('.teaser'));
        }

这可行,但如果我再次尝试 showContent(".teaser") ,它会失败,因为它似乎没有找到任何内容,因此 #content 被覆盖什么都没有。

看看我的网站看看...

http://www.shadowshapes.com/dev

最佳答案

@redsquare, 非常感谢!这让我走上了正确的道路。

对于新手来说,append() 在单个选择器上下文中的作用类似于“移动”而不是“复制”。显然这是新手中的一个常见错误。而且它没有完全记录?我现在感觉没那么糟糕了! :)

http://www.nabble.com/Undocumented-move-copy-behavior-of-append%28%29-et-al.-ts21179461s27240.html#a24146606

因此,在这种情况下,除了 append() 之外,我还需要使用 clone()

$('#content').append($response.find('div.concept' + tag).clone());

太棒了!问题解决了!

关于jQuery find() 只对 AJAX 结果起作用一次?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1210390/

相关文章:

jquery - pjax/djax 和 ajaxy 的替代方案

php - 自动更新$_SESSION[余额]?

jquery - 使用 pjax 实现覆盖的最佳方法

javascript - 将 jQuery Mobile 用于数据驱动应用程序的正确方法?

javascript - Jquery .load() 执行后 Dropzone 不工作

javascript - 提交前检查数据

c# - 为什么我的 Ajax 不工作?

javascript - 在 ajax 查询完成之前显示加载图像的好方法是什么?

javascript - Jquery同位素过滤机制不起作用,而是页面只是刷新

jQuery animate() 忽略 firefox 上的持续时间