Àí½âjavascript closures ±Õ°ü(¶ÁÊé±Ê¼Ç)
ʲôÊDZհü(closures):
±Õ°ü¾ÍÊÇÄÚ²¿º¯Êýͨ¹ýijÖÖ·½Ê½Ê¹Æä¿É¼û·¶Î§³¬³öÁËÆä¶¨ÒåµÄ·¶Î§,Õâ¾Í²úÉúÁËÒ»¸öÔÚÆä¶¨Ò巶ΧÄڵıհü.
ÕâÊÇÎÒÀí½âºóµÄÒ»¸ö¶¨Òå,ºÇºÇ!ºÜ»Þɬ°É!²»¹ýû¹ØÏµ,¿ÉÒÔÏÈ¿´¿´ÏÂÃæµÄ½²½â.
Ò» ÄÚ²¿º¯Êý(inner function)
javascriptÊÇÖ§³ÖÄÚ²¿º¯ÊýÉêÃ÷(inner function declaration)µÄ±à³ÌÓïÑÔ,
ÄÚ²¿º¯Êý¾ÍÊÇÔÚÁíÒ»¸öº¯ÊýµÄÄÚ²¿¶¨Òå,Èç
function outerFun(){
function innerFun(){
alert('hello');
}
}
º¯ÊýinnerFun¾ÍÊÇÄÚ²¿º¯Êý, ËüÔÚº¯ÊýouterFun·¶Î§ÄÚÊǿɼûµÄ,
Ò²¾ÍÊÇ˵innerFunº¯ÊýµÄÃüÃû¿Õ¼ä(namespace)ÊÇÔÚouterFun·¶Î§Ö®ÄÚ.
ÕýÈ·µ÷ÓÃ:
function outerFun(){
function innerFun(){
alert('hello');
}
innerFun();
}
outerFun(); //alerts "hello"
´íÎóµ÷ÓÃ(error):
function outerFun(){
function innerFun(){
alert('hello');
}
}
innerFun();
ÄÇôÈç¹ûÎÒÏëÔÚº¯ÊýouterFunÍâÃæµ÷Óú¯ÊýinnerFun,ÎÒ¸ÃÈçºÎ×öÄØ?
×ö·¨1:
var globVar;
function outerFun() {
function innerFun() {
alert('hello');
}
globVar = innerFun;
}
outerFun();
globVar();
×ö·¨2:
function outerFun() {
function innerFun() {
alert('hello');
}
return innerFun ;
}
var globVar = outerFun();
globVar();
×ö·¨3:
function outerFun() {
function innerFun() {
alert('hello');
}
return {'innerFun':innerFun} ;
}
var globVar = outerFun();
globVar.innerFun();
ÒÔÉÏÈýÖÖ×ö·¨°ÑÄÚ²¿º¯ÊýµÄ¿É¼û·¶Î§À©´óÁË, ÆäÖÐ×îºóÒ»ÖÖ×ö·¨ÊǰÑÄÚ²¿º¯Êýµ±×öÄäÃû¶ÔÏó{'innerFun':innerFun}µÄÊôÐÔ,²¢ËæÖ®Ò»Æð·µ»Ø.
´ÓÖп´µ½ÔÚjavascriptÀïÃæ,º¯ÊýÃû³Æ¿ÉÒÔµ±×÷ÊÇÒ»ÖÖÒýÓñäÁ¿,ÀàËÆÓÚcÀïÃæÖ¸ÕëµÄ¸ÅÄî,ÔÚÕâÀï,Ëæ×ųÌÐòµÄÖ´ÐÐ
»á²úÉúÁ½¸öÒýÓñäÁ¿Ö¸ÏòÄÚ²¿º¯ÊýinnerFun,Ò»¸öÊÇglobVar(µÚÈýÖÖ×ö·¨ÊÇglobVar.innerFun),ÁíÒ»¸öÊÇÆäº¯Êý×ÔÉíinnerFun,
Ö»²»¹ýÕâÁ½¸ö±äÁ¿µÄ¿É¼û·¶Î§²»Ò»Ñù,¼´ÃüÃû¿Õ¼ä²»Ò»Ñù.
javascriptÀ¬»ø»ØÊÕÆ÷»áÔÚº¯Êý×îºóÒ»¸öÒýÓñäÁ¿±»·ÏÆúºó,ÊÍ·ÅÆäËùÕ¼ÓõÄÄÚ´æ.
¶þ ±äÁ¿·¶Î§
Àý1 ÄÚ²¿º¯Êý±äÁ¿
ÔÚÄÚ
Ïà¹ØÎĵµ£º
event´ú±íʼþµÄ״̬£¬ÀýÈç´¥·¢event¶ÔÏóµÄÔªËØ¡¢Êó±êµÄλÖü°×´Ì¬¡¢°´ÏµļüµÈµÈ¡£
event¶ÔÏóÖ»ÔÚʼþ·¢ÉúµÄ¹ý³ÌÖвÅÓÐЧ¡£
eventµÄijЩÊôÐÔÖ»¶ÔÌØ¶¨µÄʼþÓÐÒâÒå¡£±ÈÈ磬fromElement ºÍ toElement ÊôÐÔÖ»¶Ô onmouseover ºÍ onmouseout ʼþÓÐÒâÒå¡£
Àý×Ó
ÏÂÃæµÄÀý×Ó¼ì²éÊó±êÊÇ·ñÔÚÁ´½ÓÉϵ¥»÷£¬²¢ÇÒ£¬Èç¹ûshift¼ü±»°´Ï ......
1.document.write(""); Êä³öÓï¾ä
2.JSÖеÄ×¢ÊÍΪ//
3.´«Í³µÄHTMLÎĵµË³ÐòÊÇ:document->html->(head,body)
4.Ò»¸öä¯ÀÀÆ÷´°¿ÚÖеÄDOM˳ÐòÊÇ:window->(navigator,screen,history,location,document)
5.µÃµ½±íµ¥ÖÐÔªËØµÄÃû³ÆºÍÖµ:document.getElementById("±íµ¥ÖÐÔªËØµÄIDºÅ").name(»òvalue)
6.Ò»¸öСдת´ó ......
Ò»¸ö¿ÉÍϷŵģʣÓЧ¹û;
var isIE = (document.all) ? true : false;
var $ = function (id) {
return "string" == typeof id ? document.getElementById(id) : id;
};
var Class = {
create: function() {
return function() { this.initialize.apply(this, arguments); }
}
}
var Extend = function( ......
javascriptµÃµ½ÆÁÄ»·Ö±æÂʺÍÍøÒ³¿É¼ûÇøÓòµÈ·½·¨
<body><SCRIPT LANGUAGE="JavaScript">...
var s = "";
s&n ......
ÄÄλʦ¸çʦ½ãÄܹ»°ïæ½â¾öһϣ¬ÔÚjsp½Å±¾ÖÐÄÜ·ñµ÷ÓÃjavascriptº¯Êý£¬Èç¹ûÄÜÔõôµ÷Óã¿
¾ÍÊÇ˵¼ÙÈçÒ»¸öjavascript º¯ÊýÓÐÒ»¸ö·µ»ØÖµÈçreturn“a”;
ÔÚjsp½Å±¾ÖÐÉùÃ÷Ò»¸öStringÀàÐ͵ıäÁ¿Ôõôµ÷ÓÃÉÏÃæµÄº¯ÊýÀ´½ÓÊÜ·µ»ØµÄÖµ£¡
Ï£ÍûÄܰïæ½â¾öÏÂ,ллÁË£¡ ......