Я немного очистил код и сделал его подключаемым.Не очень элегантно (код не был хорош для начала), но оно должно работать:
jQuery.fn.twitterMenu = function() {
return this.each(function() {
var dropdown = $(this);
var menu = dropdown.next('div.dropdown-menu');
var parent = dropdown.parent();
var activeClass = 'dropdown-active';
var showingDropdown = false;
var showingDropdown, showingMenu, showingParent;
dropdown.click(function(e) {
e.stopPropagation();
e.preventDefault();
if (showingDropdown) {
dropdown.removeClass(activeClass);
showingMenu.hide();
showingDropdown = false;
} else {
showingDropdown = true;
showingMenu = menu;
showingParent = parent;
menu.show();
dropdown.addClass(activeClass);
}
});
$('body').click(function(e) {
if (showingParent) {
var parentElement = showingParent[0];
if (!$.contains(parentElement, e.target) || !parentElement == e.target) {
hideMenu();
}
}
});
});
};
Вы используете это так:
$(document).ready(function() {
$('.dropdown').twitterMenu();
});
Демо: http://jsfiddle.net/DraY4/9/