O'Reilly

Hot Effect: MooTools Drag Opacity

By on  
MooTools Drag Opacity

As you should already know, the best visual features of a website are usually held within the most subtle of details. One simple trick that usually makes a big different is the use of opacity and fading. Another awesome MooTools functionality is dragging. Why not double the awesomeness of Element dragging by adding fading?

The MooTools JavaScript

window.addEvent('domready',function() {
	var z = 2;
	$$('.draggable').each(function(el) {
		var drag = new Drag.Move(el,{
			grid: false,
			preventDefault: true,
			onStart: function() {
				el.setStyle('z-index',z++).fade(0.5);
			},
			onComplete: function() {
				el.fade(1);
			}
		});
	});
});

The code itself is quite simple -- we use Drag.Move's onStart and onComplete events to begin and end the fading. We've chosen to fade to the desired opacity level over a given duration because a subtle fade is a bit less drastic. We could simply use set('opacity','0.5') if we wanted an immediate fade.

I consider the above effect a "cheap" way to increase the coolness of element dragging. Very little overhead and just another effect to take your website to the next level!

Track.js Error Reporting

Recent Features

  • Send Text Messages with PHP

    Kids these days, I tell ya.  All they care about is the technology.  The video games.  The bottled water.  Oh, and the texting, always the texting.  Back in my day, all we had was...OK, I had all of these things too.  But I still don't get...

  • LightFace:  Facebook Lightbox for MooTools

    One of the web components I've always loved has been Facebook's modal dialog.  This "lightbox" isn't like others:  no dark overlay, no obnoxious animating to size, and it doesn't try to do "too much."  With Facebook's dialog in mind, I've created LightFace:  a Facebook lightbox...

Incredible Demos

  • Fullscreen API

    As we move toward more true web applications, our JavaScript APIs are doing their best to keep up.  One very simple but useful new JavaScript API is the Fullscreen API.  The Fullscreen API provides a programmatic way to request fullscreen display from the user, and exit...

  • MooTools Zebra Table Plugin

    I released my first MooTools class over a year ago. It was a really minimalistic approach to zebra tables and a great first class to write. I took some time to update and improve the class. The XHTML You may have as many tables as...

Discussion

  1. wow, that is a really nice effect. i lub ur blog

  2. I recently found the Drag.Ghost extension at http://www.monkeyphysics.com/mootools/script/1/dragghost

    It’s the only way I do drag/drop with mootools these days. A very handy extension.

  3. Hey, I’m not seeing this work so well. Shouldn’t the box always pop up on top when dragging? I’m seeing it sometimes stay behind the other boxes. (I’m using Google Chrome 3.0.195.38)

  4. @Dwight Blubaugh: Good catch — I’ve updated the code to prevent that issue. w00t!

  5. Better, but now only on the first time drag the box will go transparent and only be in front of boxes to the left.

  6. @Dwight Blubaugh: Good catch — was only happening on the first drag so I’ve upped the starting number to 2 and that seems to have fixed the issue.

  7. Vitor

    Also just a question, why does the box changes shape when you drag it to the top of the adds?

    Looks really nice!!!

  8. @vitor – I can only guess that it’s because the drag boxes don’t have a fixed with, so when they get to the right side of their parent they try to adjust their shape to fit inside. See how the text changes also?

  9. If i set a width on them (through firebug) then they don’t adjust shape… Interesting quirk…

  10. Love the z-index trick to keep them on top David.

    @vivitor: position: absolute block elements with width: auto set their width similar to floated elements, just enough for the content inside + padding + border. Each box has the same text, therefore the same width. When they hit the side of the parent element the width adjusts accordingly.

    Pop open the inspector and change the text inside one and you’ll see the width changes to accommodate it.

  11. What if I’d like to prevent the boxes to be moved on some part of the page (header, for instance?)

  12. Wow, awesome feature.

  13. @marcoverga: http://mootools.net/docs/more/Drag/Drag#Drag:stop

    Check the position of the element relative to whatever you want and then call stop();

  14. great effect. i will use it in my next projects

  15. Alex

    monkeyphysics plug in +1

  16. leo

    when you click the block that can be move to top…..

  17. This code is really small, nothing complicated, as looked like.we can set as well for how long is going to work. Really good stuff, java make it easier.

Wrap your code in <pre class="{language}"></pre> tags, link to a GitHub gist, JSFiddle fiddle, or CodePen pen to embed!

Recently on David Walsh Blog

  • Convert Video to mp3

    Let's all be honest for a moment:  we've all ... not paid for ... music.  Whether it was via a file sharing app like Kazaa or Napster, or it was downloading and seeding on bittorrent, or maybe even downloading a music video and ripping its audio,...

  • Sort git Branches by Date

    I'll be first person to admit I don't do as much git repository maintenance as I should.  I rarely delete branches which have been merged, so a git branch execution shows me a mile-long list of branches that likely aren't relevant.  The best way to find branches I've recently...

  • Best Tools and Resources for Web Professionals in 2015

    Looking for the right resources to help you satisfy the needs of your clients? On the lookout for the best tools to help you increase your revenue? Searching for the right software to help you improve your business? Well, then you’ve come to the right place....

  • JavaScript Polling

    Polling with JavaScript is one of those ugly but important functions within advanced front-end user experience and testing practices.  Sometimes there isn't the event you can hook into to signify that a given task is complete, so you need to get your hands dirty and simply poll for...

  • OSCON Portland:  Conference Giveaway and Discount!

    O'Reilly puts on the best web industry conferences in the world.  These conferences include Fluent Conference, Velocity Conference, and the upcoming OSCON in Portland, Oregon from July 20-24.  Open Source Convention (OSCON) is a conference that focuses specifically on open source developers and the tools and possibilities...