0

我正在尝试用数据切换文本“显示更多”和“显示更少”,我的脚本几乎可以工作,但我需要它在变成文本“显示更少”并继续切换“显示更多”和“少显示”。我的功能中缺少什么?

这是我的jsfiddle:http: //jsfiddle.net/Manna/3Ndcg/1/

<div class ="scorer_filter">
 <a href="#" class="hide_full_list" data-less="Show Less" data-more="Show More" data-table-id="32301" id="toggle">Show More</a>
</div>

  $(function() {
  $(".scorer_filter").on("click", ".hide_full_list", function(){
  var txt = "Show More" ? $('#toggle').data("less") : $('#toggle').data("more");
  $('#toggle').text(txt);
});

});

4

3 回答 3

1

给你

  $(function() {
    $(".scorer_filter").on("click", ".hide_full_list", function(){
      var txt = $(this).text() == "Show More" ? $(this).data("less") : $(this).data("more");
      $(this).text(txt);
    });
  });
于 2014-03-31T21:50:05.960 回答
1

var txt = "Show More" ? $('#toggle').data("less") : $('#toggle').data("more");

坏了,它总是把“显示更多”放在txt中。尝试这样的事情:

   $(function() {
        $(".scorer_filter").on("click", ".hide_full_list", function(){
            if ($('#toggle').data("less")) {
                $('#toggle').data("less",false).text("Show less");
            } else {
                $('#toggle').data("less",true).text("Show more");
            }
        });
    });
于 2014-03-31T21:53:16.857 回答
0

您没有在代码中测试“txt”变量。你应该这样做:

var txt = $('#toggle').text();
txt = (txt == "Show More") ? $('#toggle').data("less") : $('#toggle').data("more");

http://jsfiddle.net/3Ndcg/2/

于 2014-03-31T21:49:02.247 回答