求助对一个对象添加点击事件并把事件的内容封装到一个函数内怎么做?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

求助对一个对象添加点击事件并把事件的内容封装到一个函数内怎么做?

2016-05-31 15:23:48 3865 1
 $(".banner li").click(function() {
      var $li = $(this);
      var i = $li.text() - 1;   //0,1,2,3
                                // if (i >= count) return;
      $(".banner-list i")
              .filter(":visible")
              .fadeOut(400)
              .parent()
              .children()
              .eq(i)
              .fadeIn(400);
      $li.addClass("cur");
      $li.siblings().removeClass("cur");
  }

想把事件触发后执行的效果封装到一个函数action内,点击后直接调用这个函数,但是this总是搞不明白,封装后的函数action该怎么写呢?这是一个简单的轮播图的效果,意思就是我怎么在action函数内监听我点击的是哪个li标签

取消 提交回答
全部回答(1)
  • 吴孟桥
    2019-07-17 19:22:03

    一样的,你的函数内的this对象还是指向点击的li对象

      function Action(){
            var $li = $(this);
            var i = $li.text() - 1;   //0,1,2,3
                                      // if (i >= count) return;
            $(".banner-list i")
                    .filter(":visible")
                    .fadeOut(400)
                    .parent()
                    .children()
                    .eq(i)
                    .fadeIn(400);
            $li.addClass("cur");
            $li.siblings().removeClass("cur");
     }
     $(".banner li").click(Action);
    0 0
+关注
0
文章
2240
问答
问答排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载