別の開発者が作成したこのコードを理解しようとしていますが、JavaScript の知識が不足しています。この関数は、サイトのヘッダー メニューを受け取り、それをモバイル スタイルのメニューに変換することになっています。
jQuery が として渡される理由を理解してい$
ます。CPCU
変数がどのようにそれ自体に返されるのか、またはなぜ として返されるのかわかりませんCPCU || {}
。CPCU
この状況で変数がどのように機能しているかを誰かが理解するのを手伝ってくれますか?
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);