我最近遇到了一段代码。它如下:
var myFeature = {
'config' : {
'container' : $('#myFeature')
},
'init' : function(config) {
if (config && typeof(config) == 'object') {
$.extend(myFeature.config, config);
}
myFeature.$container = myFeature.config.container;
myFeature.$sections = myFeature.$container.
find('ul.sections > li');
myFeature.$section_nav = $('<ul/>').
attr('id','section_nav').
prependTo(myFeature.$container);
myFeature.$item_nav = $('<ul/>').
attr('id','item_nav').
insertAfter(myFeature.$section_nav);
myFeature.$content = $('<div/>').
attr('id','content').
insertAfter(myFeature.$item_nav);
myFeature.buildSectionNav(myFeature.$sections);
myFeature.$section_nav.find('li:first').click();
myFeature.$container.find('ul.sections').hide();
myFeature.initialized = true;
},
'buildSectionNav' : function($sections) {
$sections.each(function() {
var $section = $(this);
$('<li/>').
text($section.find('h2:first').text()).
appendTo(myFeature.$section_nav).
data('section', $section).
click(myFeature.showSection);
});
},
'buildItemNav' : function($items) {
$items.each(function() {
var $item = $(this);
$('<li/>').
text($item.find('h3:first').text()).
appendTo(myFeature.$item_nav).
data('item', $item).
click(myFeature.showContentItem);
});
},
'showSection' : function() {
var $li = $(this);
myFeature.$item_nav.empty();
myFeature.$content.empty();
var $section = $li.data('section');
$li.addClass('current').
siblings().removeClass('current');
var $items = $section.find('ul li');
myFeature.buildItemNav($items);
myFeature.$item_nav.find('li:first').click();
},
'showContentItem' : function() {
var $li = $(this);
$li.addClass('current').
siblings().removeClass('current');
var $item = $li.data('item');
myFeature.$content.html($item.html());
}
};
我知道$('#myFeature'),$(this)的含义。 但是$ li和myFeature。$ container是什么意思? 它们是某种变量吗? 如果是这样,myFeature的范围是什么。$ container?因为它没有使用var声明,它是全局的吗?
答案 0 :(得分:10)
$li
和$container
只是变量名,这样命名,所以程序员知道它们是jQuery扩展对象。
答案 1 :(得分:2)
这只是公共变量,$被授权成为var名称的一部分,而作者只想在开始时用$命名他的变量。关于myFeature。$ container这只是myFeature对象的一个属性,所以它与myFeature的范围相同
答案 2 :(得分:2)
不,这只是一个简单的变量名 我对包含jquery对象的变量做同样的事情,以便快速将它们与我的其他(非jquery)变量区分开来。
答案 3 :(得分:2)
在使用像jQuery这样的框架时,程序员通常会在变量名前加上$符号,这样他就知道内容是一个jQuery对象。
因此,例如,当您绑定click事件并在函数内部时,您可以使用变量this
。但this
引用dom元素而不引用jquery对象。
例如,您可以使用类似的东西来识别变量的值:
var $this = $(this);
$this.doSomeJquery();
答案 4 :(得分:2)
它只允许您从JavaScript变量中轻松识别jQuery变量。
例如:
var $section = $li.data('section'); //jQuery variable
var num = 2; //JavaScript variable
如果你有很多带有JavaScript和jQuery变量的代码,那么它会非常有用。
答案 5 :(得分:1)
美元符号($)是“JQuery”的别名
我的意思是
$(document).ready(function(){
});
就像写:
jQuery(document).ready(function(){
});
编辑:我想念解释这个问题,对不起。
是的,是变量名称
答案 6 :(得分:0)
我说这只是一些代码约定,表明它是一个包含Jquery对象(而不是DOM对象)的变量。
答案 7 :(得分:0)
如果你看一下JQuery源代码(http://bit.ly/jqsource) - 最后,你会看到:
// Expose jQuery to the global object
window.jQuery = window.$ = jQuery;
它只是对window.jQuery
的引用。