Ich versuche, diesen Code von einem anderen Entwickler zu verstehen, und meine JavaScript-Kenntnisse fehlen. Diese Funktion soll das Header-Menü einer Site übernehmen und in ein mobiles Style-Menü umwandeln.Funktionsausdruck in JavaScript Verwirrung
Ich verstehe, warum jQuery als $
übergeben wird. Ich verstehe nicht, wie die Variable CPCU
in sich zurückgereicht wird oder warum sie als CPCU || {}
zurückgegeben wird. Kann mir jemand helfen zu verstehen, wie die Variable CPCU
in dieser Situation funktioniert?
var CPCU = (function (_cpcu, $) {
'use strict';
/**
* Mobile Menu
*/
var mmenu = _cpcu.Menu.mobile = _cpcu.Menu.mobile || {};
// Properties.
mmenu.id = '#mobile-menu';
mmenu.el = $('');
mmenu.api = {};
mmenu.button = '#header-content .menu.button';
mmenu.aniClass = 'animate';
mmenu.opts = {
slidingSubmenus: false
};
mmenu.config = {
classNames: {
selected: 'active'
}
};
// Methods.
mmenu.init = function() {
mmenu.el = $(mmenu.id);
// Move the active class to from the A to the LI, must happen before mmenu init.
$('#mobile-menu').find('a.active').parent('li').addClass('active');
// Now we can init the menu. otherwise it doesn't pick up the active LI.
mmenu.api = mmenu.el.mmenu(mmenu.opts, mmenu.config).data('mmenu');
mmenu.button = $(mmenu.button);
mmenu.button.data('lines', $('.line1,.line2,.line3'));
mmenu.button.click(function() {
mmenu.api.open();
});
mmenu.api.bind('open', function() {
mmenu.button.data('lines').addClass(mmenu.aniClass);
});
mmenu.api.bind('close', function() {
mmenu.button.data('lines').removeClass(mmenu.aniClass);
});
};
// Set up doc ready.
$(document).ready(function() {
mmenu.init();
});
return _cpcu;
})(CPCU || {}, jQuery);
Sehen Sie sich diese verwandte Frage an: [Was bedeutet "var FOO = FOO || {} "(Weisen Sie dieser Variablen eine Variable oder ein leeres Objekt zu) in Javascript?] (Http://stackoverflow.com/questions/6439579/what-does-var-foo-foo-assign-a-variable-or -an-empty-object-to-that-va) –