2014-12-11 162 views
0

大家好!jQuery PageSlide:點擊.css功能

我使用這個插件:PageSlide這是jquery.pageslide.js代碼:

(function($) { 
    var $body = $("body"), 
    $pageslide = $("#pageslide"); 
    var 
    _sliding = false, 
    _lastCaller; 
    if ($pageslide.length == 0) { 
    $pageslide = $("<div />").attr("id", "pageslide").css("display", "none").appendTo($("body")); 
    } 

    function 
    _load(url, useIframe) { 
    if (url.indexOf("#") === 0) { 
     $(url).clone(true).appendTo($pageslide.empty()).show(); 
    } else { 
     if (useIframe) { 
     var 
      iframe = $("<iframe 
/>").attr({ 
      src: url, 
      frameborder: 0, 
      hspace: 0 
      }).css({ 
      width: "100%", 
      height: "100%" 
      }); 
     $pageslide.html(iframe); 
     } else { 
     $pageslide.load(url); 
     } 
     $pageslide.data("localEl", false); 
    } 
    } 

    function 
    _start(direction, speed) { 
    var slideWidth = $pageslide.outerWidth(true), 
     bodyAnimateIn = {}, 
     slideAnimateIn = {}; 
    if ($pageslide.is(":visible") || _sliding) { 
     return; 
    } 
    _sliding = true; 
    switch (direction) { 
     case "left": 
     $pageslide.css({ 
      left: "auto", 
      right: "-" + slideWidth + "px" 
     }); 
     bodyAnimateIn["margin-left"] = "-=" + slideWidth; 
     slideAnimateIn["right"] = "+=" + slideWidth; 
     break; 
     default: 
     $pageslide.css({ 
      left: "-" + slideWidth + "px", 
      right: "auto" 
     }); 
     bodyAnimateIn["margin-left"] = "+=" + slideWidth; 
     slideAnimateIn["left"] = "+=" + slideWidth; 
     break; 
    } 
    $body.animate(bodyAnimateIn, speed); 
    $pageslide.show().animate(slideAnimateIn, speed, function() { 
     _sliding = false; 
    }); 
    } 
    $.fn.pageslide = function(options) { 
    var 
     $elements = this; 
    $elements.click(function(e) { 
     var 
     $self = $(this), 
     settings = $.extend({ 
      href: $self.attr("href") 
     }, options); 
     e.preventDefault(); 
     e.stopPropagation(); 
     if ($pageslide.is(":visible") && $self[0] == _lastCaller) { 
     $.pageslide.close(); 
     } else { 
     $.pageslide(settings); 
     _lastCaller = $self[0]; 
     } 
    }); 
    }; 
    $.fn.pageslide.defaults = { 
    speed: 200, 
    direction: "right", 
    modal: false, 
    iframe: true, 
    href: null 
    }; 
    $.pageslide = function(options) { 
    var 
     settings = $.extend({}, $.fn.pageslide.defaults, options); 
    if ($pageslide.is(":visible") && $pageslide.data("direction") != settings.direction) { 
     $.pageslide.close(function() { 
     _load(settings.href, settings.iframe); 
     _start(settings.direction, settings.speed); 
     }); 
    } else { 
     _load(settings.href, settings.iframe); 
     if ($pageslide.is(":hidden")) { 
     _start(settings.direction, settings.speed); 
     } 
    } 
    $pageslide.data(settings); 
    }; 
    $.pageslide.close = function(callback) { 
    var 
     $pageslide = $("#pageslide"), 
     slideWidth = $pageslide.outerWidth(true), 
     speed = $pageslide.data("speed"), 
     bodyAnimateIn = {}, 
     slideAnimateIn = {}; 
    if ($pageslide.is(":hidden") || _sliding) { 
     return; 
    } 
    _sliding = true; 
    switch ($pageslide.data("direction")) { 
     case "left": 
     bodyAnimateIn["margin-left"] = "+=" + slideWidth; 
     slideAnimateIn["right"] = "-=" + slideWidth; 
     break; 
     default: 
     bodyAnimateIn["margin-left"] = "-=" + slideWidth; 
     slideAnimateIn["left"] = "-=" + slideWidth; 
     break; 
    } 
    $pageslide.animate(slideAnimateIn, speed); 
    $body.animate(bodyAnimateIn, speed, function() { 
     $pageslide.hide(); 
     _sliding = false; 
     if (typeof callback != "undefined") { 
     callback(); 
     } 
    }); 
    }; 
    $pageslide.click(function(e) { 
    e.stopPropagation(); 
    }); 
    $(document).bind("click 
keyup", function(e) { 
    if (e.type == "keyup" && e.keyCode != 27) { 
     return; 
    } 
    if ($pageslide.is(":visible") && !$pageslide.data("modal")) { 
     $.pageslide.close(); 
    } 
    }); 
})(jQuery); 

我需要多一個功能: 時PageSlide激活 - 這樣的左側菜單已打開 - [內容]寬度div更改爲600px,當處於非活動狀態時,將變回原始1200px。

我認爲好的代碼是:$('#content').css('width', '600px');,但我不知道該把它放在哪裏。我不太瞭解JavaScript。

謝謝!

回答

1

看起來_start()函數是調用$ pageslide元素的函數。嘗試將其他更改添加到該功能。

_start(direction, speed) { 
 
    var slideWidth = $pageslide.outerWidth(true), 
 
     bodyAnimateIn = {}, 
 
     slideAnimateIn = {}, 
 
     //may want to declare this somewhere else so its not fetched every time from the dom 
 
     $content = $('#content'); 
 
    if ($pageslide.is(":visible") || _sliding) { 
 
     return; 
 
    } 
 
    _sliding = true; 
 
    switch (direction) { 
 
     case "left": 
 
     $pageslide.css({ 
 
      left: "auto", 
 
      right: "-" + slideWidth + "px" 
 
     }); 
 
     bodyAnimateIn["margin-left"] = "-=" + slideWidth; 
 
     slideAnimateIn["right"] = "+=" + slideWidth; 
 
     // Looks like the default for direction is set to 'right', so this would be when its closing 
 
     $content.css({ 
 
      width: '1200px' 
 
     }) 
 
     break; 
 
     default: 
 
     $pageslide.css({ 
 
      left: "-" + slideWidth + "px", 
 
      right: "auto" 
 
     }); 
 
     bodyAnimateIn["margin-left"] = "+=" + slideWidth; 
 
     slideAnimateIn["left"] = "+=" + slideWidth; 
 
     //this should be when its opening. If not, just switch the two inserted statements. 
 
     $content.css({ 
 
      width: '600px' 
 
     }) 
 
     break; 
 
    }

+0

的短路到600px的是好的,但回原來的大小不是:( – user3034899 2014-12-11 15:35:12