Mootools JavaScript DHTML





  
  
div.demoElement {
  width: 80px;
  height: 80px;
  border: 1px solid black;
  background-color: #f9f9f9;
  font-size: 12px;
  color: #000000;
  padding: 10px;
}
div.demoElementHeight {
  height: 120px;
}
.myClass {
  width: 300px;
  height: 50px;
  border: 3px dashed black;
  background-color: #C6D880;
  font-size: 20px;
  padding: 20px;
}  
  
  
  
  
window.addEvent('domready', function() {
  var el = $('myElement');
  
  // MooTools is able to handle effects without the use of a wrapper,
  // so you are able to do effects with just one easy line.
  
  //FIRST EXAMPLE
  
  // There are different ways to add a fading opacity effect to an element click
  
  // Short version
  $('fadeOpacity').addEvent('click', el.fade.bind(el, [0]));
  
  // Long version
  $('tweenOpacity').addEvent('click', function(e) {
    // You often will need to stop propagation of the event
    e.stop();
    el.fade(1);
  });
  
  $('tweenOpacity1').addEvent('click', function(e) {
    e.stop();
    el.fade(0.3);
  });
  
  
  //SECOND EXAMPLE
  var otherEl = $('myOtherElement');
  
  $('heightEffect').addEvent('click', function(){
    otherEl.tween('height', 50);
    return false; // alternative syntax to stop the event
  });
  
  // We can also create an Fx.Tween instance and use a wrapper variable
  
  var myEffect = new Fx.Tween(otherEl);
  $('colorEffect').addEvent('click', function(e) {
    e.stop();
    // We change the background-color of the element
    myEffect.start('background-color', '#E6EFC2');
  });
  
  $('borderEffect').addEvent('click', function(e) {
    e.stop();
    otherEl.tween('border', '10px dashed #C6D880');
  });
  
  $('resetEffect').addEvent('click', function(e) {
    e.stop();
    otherEl.erase('style');
  });
  
  
  //THIRD EXAMPLE
  
  var anotherEl = $('anotherElement');
  
  // Again we are able to create a morph instance
  var morph = new Fx.Morph('anotherElement');
  
  $('morphEffect').addEvent('click', function(e) {
    e.stop();
    morph.start({
      width: '200px',
      color: '#C6D880'
    });
  });
  
  // Or we just use Element.morph
  $('CSSmorphEffect').addEvent('click', function(e) {
    e.stop();
    // Changes the element's style to .myClass defined in the CSS
    anotherEl.morph('.myClass');
  });
  
  $('resetEffect1').addEvent('click', function(e) {
    e.stop();
    // You need the same selector defined in the CSS-File
    anotherEl.morph('div.demoElement');
  });
});  
  
  Effects Introduction


  

Effects Introduction


  

Introduction


  


    The powerful Effects-Classes allow you to change any number of css styles with
    any transition and any duration.
  


  


    Fade opacity to 0
    |
    Tween opacity to 1
    |
    Tween opacity to 0.3
  


  
  

  
  


    Height-Effect
    |
    Backgroundcolor-Effect
    |
    Border-Effect
    |
    Reset
  


  
    
    

  

  
  


    Morph!
    |
    Morph to CSS-Class .myClass
    |
    Reset
  


  
    
      Demo Text