更改链接名称和切换jquery扩展时的图像

时间:2012-01-25 17:30:07

标签: php jquery toggle collapse

我使用以下代码在点击链接时展开/折叠某些文字

我需要在文本展开时将链接名称更改为“隐藏”,并且具有不同的图像(即arrow_up.png)。

我该怎么做?

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
    var $divView = $('div.view');
    var innerHeight = $divView.removeClass('view').height();
    $divView.addClass('view');

    $('div.slide').click(function() {
        $('div.view').animate({
          height: (($divView.height() == 90)? innerHeight  : "90px")
        }, 500);
        return false;
    });
});
</script>
<div class="view">
  <ul class="moduleItemExtraFields">
        <li>text here</li>
        <li>text here</li>
        <li>text here</li>
        <li>text here</li>
        <li>text here</li>
        <li>text here</li>
        <li>text here</li>
        <li>text here</li>
        <li>text here</li>
  </ul>
</div>
<div class="slide">Show <img src="images/arrow_down.png" /></div>

2 个答案:

答案 0 :(得分:1)

<script type="text/javascript">

    //...

    $('div.slide').click(function() {

        // Update the HTML in this element
        var slideHtml = $(this).html();

        // Switch between show/hide
        if (slideHtml.localeCompare('Show <img src="images/arrow_up.png" />') < 0)
           $(this).html('Show <img src="images/arrow_up.png" />');
        else
           $(this).html('Hide <img src="images/arrow_down.png" />');

        $('div.view').animate({
          height: (($divView.height() == 90)? innerHeight  : "90px")
        }, 500);
        return false;
    });

    //...
</script>

答案 1 :(得分:0)

我会在div.slide中添加/删除类以检查它是否展开或崩溃。

DEMO此处

  $('div.slide').addClass('expanded');

  $('div.slide').click(function() {

    if ($(this).hasClass('collapsed')) {
        $('div.view').animate({ //expand
            height: (($divView.outerHeight() == 90) ? innerHeight : "90px")
        }, 500, function () {
         $divSlide.removeClass('collapsed').addClass('expanded');

         $divSlide.html ('Hide <img src="http://www.auto123.com/site/img/used/up_arrow.gif" />');
        });            

    } else {
        $('div.view').animate({
            height: '0px'
        }, 500, function () {
         $divSlide.removeClass('expanded').addClass('collapsed');

         $divSlide.html ('Show <img src="http://listedmag.com/images/down_arrow.gif" />');            

        }); //collapse
    }