Javascript slide effect onclick

前端 未结 1 432
遇见更好的自我
遇见更好的自我 2021-01-23 12:26

I\'d like to add a slide & fade effect to a DIV, with purely Javascript, using \"onclick\".

The code is here: http://jsfiddle.net/TCUd5/

The DIV that has to

1条回答
  •  别那么骄傲
    2021-01-23 13:00

    jQuery is a lot easier, but with pure javascript you can do it.

    In the CSS you'll need to use transitions

    #thing { position:relative;
      top: 0px;
      opacity: 0.8;
      -moz-transition: top 1s linear, opacity 1s linear;
      -webkit-transition: top 1s linear, opacity 1s linear;
     }
    

    then in the javascript when you change the position of the element, it should change via the css transitions.

    var toggleUpdatesPulldown = function(event, element, user_id) {
      if( element.className=='updates_pulldown' ) {
         element.style.top = someValue; //something like '100px' will slide it down 100px
         element.style.opacity = '1.0'; //will fade the content in from 0.8 opacity to 1.0
         element.className= 'updates_pulldown_active';
        showNotifications();
    



    EDIT - provided jQuery code

    call the jQuery library, most easily done from the google hosting

    
    

    make the hover function

    $(document).ready(function() {
            $('.updates_pulldown').hover( //first function is mouseon, second is mouseout
                function() {
                    $(this).animate({top: '50px'}).animate({opacity: '1.0'});
                },
                function() { //delay 1000 milliseconds, animate both position and opacity
                    $(this).delay(1000).animate({top: '0px'}).animate({opacity: '0.5'});
                }
            )
        })
    

    the function timing will be the same as whatever you set it to in the css with transition tags. using 'this' instead of the class name again makes sure that the effect only occurs on the specific instance of the class that is hovered over. im not sure if this animation is exactly what you were asking for, but if i understand the question correctly then the main functionality will work for you. just change the numbers and such to fit your needs.

    0 讨论(0)
提交回复
热议问题