目录
回复内容:
首页 后端开发 php教程 javascript - js中ajax请求数据之后的click事件失效问题

javascript - js中ajax请求数据之后的click事件失效问题

Jul 06, 2016 pm 01:52 PM
ajax javascript php

我有一个数据列表,列表中有点击展开效果。由于这个数据列表用到了ajax加载,就是ajax加载之后的click时间不起作用了,希望各位大神帮忙看看。
这是html中的数据结构和页面布局

<code><div class="con-list">
    <div class="list-data">
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1603">展开</a></p>
        </div>
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1621">展开</a></p>
        </div>
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1625">展开</a></p>
        </div>
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1633">展开</a></p>
        </div>
    </div>
    <div class="list-data html-hide"></div>
</div></code>
登录后复制
登录后复制

js中的展开click事件和ajax请求如下

<code><script>
;(function($){
    //打开
    $('.open-detail').click(function(){
        $(this).parent().siblings('p[class="no-open"]').addClass('yes-open');
        $(this).text('收起');
        $(this).attr('class', 'close-detail');
    });
 //收起
    $('.close-detail').click(function(){
        $(this).parent().siblings('p[class="yes-open"]').addClass('no-open');
        $(this).text('展开');
        $(this).attr('class', 'open-detail');
    });

    //
});

function getAjaxList(_v, _c, _t){
    $.ajax({
      url : './ajax.php?op='+_v,
      type : 'post',
      dataType : 'json',
      data : {'category':_c, 'template':_t},
      success : function(msg){
                if(msg.status == 1){
                    $('.html-hide').html(msg.html);
                    $('.html-hide').siblings('div').hide();
                    $('.html-hide').show();
                } else {
                    $('.list-data').html('此处无您要的信息,到最新动态去看看吧');
                }
      }
  });
}
</script></code>
登录后复制
登录后复制

php中的div设置及数据设置

<code><?php ...
...
...

foreach ($variable as $key => $value) {
   $html .='<div class="list-data-detail">';
   $html .='<p class="no-open">'.$value['desc'].'</p>
<p>';
   $html .='</p>
<p><span>时间:'.date('Y-m-d', $value['updateTime']).'</span> | <span>来源:'.$value['author'].'</span> <a href="javascript:(0)" class="open-detail" data-id="'.$value['aid'].'">展开</a></p>';
   $html .='</div>';
}
$result['html'] = $html;
exit(json_encode($result));</code>
登录后复制
登录后复制

我在phpdiv中的样式都加了啊!可就是不行。

回复内容:

我有一个数据列表,列表中有点击展开效果。由于这个数据列表用到了ajax加载,就是ajax加载之后的click时间不起作用了,希望各位大神帮忙看看。
这是html中的数据结构和页面布局

<code><div class="con-list">
    <div class="list-data">
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1603">展开</a></p>
        </div>
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1621">展开</a></p>
        </div>
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1625">展开</a></p>
        </div>
        <div class="list-data-detail">
            <p class="no-open">消费者的信息会逐渐增多,如果有一个厂家,用更好的原料和工艺,就会迅速占领市场</p>
<p>
            </p>
<p><span>时间:2016-05-24</span> | <span>来源:本站</span> <a href="javascript:(0)" class="open-detail" data-id="1633">展开</a></p>
        </div>
    </div>
    <div class="list-data html-hide"></div>
</div></code>
登录后复制
登录后复制

js中的展开click事件和ajax请求如下

<code><script>
;(function($){
    //打开
    $('.open-detail').click(function(){
        $(this).parent().siblings('p[class="no-open"]').addClass('yes-open');
        $(this).text('收起');
        $(this).attr('class', 'close-detail');
    });
 //收起
    $('.close-detail').click(function(){
        $(this).parent().siblings('p[class="yes-open"]').addClass('no-open');
        $(this).text('展开');
        $(this).attr('class', 'open-detail');
    });

    //
});

function getAjaxList(_v, _c, _t){
    $.ajax({
      url : './ajax.php?op='+_v,
      type : 'post',
      dataType : 'json',
      data : {'category':_c, 'template':_t},
      success : function(msg){
                if(msg.status == 1){
                    $('.html-hide').html(msg.html);
                    $('.html-hide').siblings('div').hide();
                    $('.html-hide').show();
                } else {
                    $('.list-data').html('此处无您要的信息,到最新动态去看看吧');
                }
      }
  });
}
</script></code>
登录后复制
登录后复制

php中的div设置及数据设置

<code><?php ...
...
...

foreach ($variable as $key => $value) {
   $html .='<div class="list-data-detail">';
   $html .='<p class="no-open">'.$value['desc'].'</p>
<p>';
   $html .='</p>
<p><span>时间:'.date('Y-m-d', $value['updateTime']).'</span> | <span>来源:'.$value['author'].'</span> <a href="javascript:(0)" class="open-detail" data-id="'.$value['aid'].'">展开</a></p>';
   $html .='</div>';
}
$result['html'] = $html;
exit(json_encode($result));</code>
登录后复制
登录后复制

我在phpdiv中的样式都加了啊!可就是不行。

谢谢邀请。我之前也遇到这种类似的问题,也是ajax()加载完的数据导致原来加的效果失效。如下是我的处理方式

<code>// 初始化数据的时候我也是这么写的
$('.message-but').click(function(){
    // code...
});

// ajax加载后click事件不执行,又改成这样
$('.message-but').live("click",function(){
    // code...
});</code>
登录后复制

之后通过网上查询才知道这个live()其实和bind()差不多一样用,都是可以给未来元素绑定对应的触发事件,但是二者还是有区别的。两者你都试试看,希望对你有帮助

在jquery1.9+之后就没有live方法了

jQuery1.9之前的版本我们可以这样写:

<code>$("a").live("focus",function(){
  this.blur();
}); 
</code>
登录后复制

jQuery1.9之后由于live被删除了,所以应该这样写:

<code>$(document).on("focus","a",function(){
  this.blur();
}); 
</code>
登录后复制

我大致看了一下,如果你的每个list-data-detail都是通过Ajax动态加载出来的,那么你开始直接写的click事件是无法起作用的,以为你的事件绑定的时候这个DOM并不存在。
这时候,你需要使用事件委托,在jQuery里,也就是

$('.list-data').on('click', '.open-detail', function() {
    /// here goes the code
});
登录后复制

这样就行了。通过事件委托,将子元素的事件绑定到父元素上,子元素被点击之后,事件会冒泡到父元素,由父元素负责捕捉然后触发事件。

动态加载的元素要执行点击可以这样

<code>$(document).on('click','.message-but',function(){
    // code...
});</code>
登录后复制
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

CakePHP 项目配置 CakePHP 项目配置 Sep 10, 2024 pm 05:25 PM

在本章中,我们将了解CakePHP中的环境变量、常规配置、数据库配置和电子邮件配置。

适用于 Ubuntu 和 Debian 的 PHP 8.4 安装和升级指南 适用于 Ubuntu 和 Debian 的 PHP 8.4 安装和升级指南 Dec 24, 2024 pm 04:42 PM

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

CakePHP 日期和时间 CakePHP 日期和时间 Sep 10, 2024 pm 05:27 PM

为了在 cakephp4 中处理日期和时间,我们将使用可用的 FrozenTime 类。

CakePHP 文件上传 CakePHP 文件上传 Sep 10, 2024 pm 05:27 PM

为了进行文件上传,我们将使用表单助手。这是文件上传的示例。

CakePHP 路由 CakePHP 路由 Sep 10, 2024 pm 05:25 PM

在本章中,我们将学习以下与路由相关的主题?

讨论 CakePHP 讨论 CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP 是 PHP 的开源框架。它的目的是使应用程序的开发、部署和维护变得更加容易。 CakePHP 基于类似 MVC 的架构,功能强大且易于掌握。模型、视图和控制器 gu

如何设置 Visual Studio Code (VS Code) 进行 PHP 开发 如何设置 Visual Studio Code (VS Code) 进行 PHP 开发 Dec 20, 2024 am 11:31 AM

Visual Studio Code,也称为 VS Code,是一个免费的源代码编辑器 - 或集成开发环境 (IDE) - 可用于所有主要操作系统。 VS Code 拥有针对多种编程语言的大量扩展,可以轻松编写

CakePHP 创建验证器 CakePHP 创建验证器 Sep 10, 2024 pm 05:26 PM

可以通过在控制器中添加以下两行来创建验证器。

See all articles