当前位置: 首页 > 后端技术 > Node.js

这在JS中到底是什么?

时间:2023-04-03 18:01:50 Node.js

JS涓殑this鍒板簳鏄粈涔堝鏋滀綘杩樻病鏈夌郴缁熷湴浜嗚В杩囷紝涔熻JavaScript涓殑this涓€鐩存槸涓皽銆備篃璁镐綘瑙佽繃鏃犳暟鍍廲onstthat=this;杩欐牱鐨勮〃杈惧紡銆傚湪Vue涓璫onstthat=this;constobj={message:"I'mobj.",printThis:function(){console.log(this);},printThat:function(){console.log(that);},};obj.printThis();obj.printThat();涓轰粈涔堣鐢╟onstthat=this;寰楀埌姝g‘鐨勮繖涓紵鏄繖鏍风殑锛屽浜庝竴涓嚱鏁颁腑鐨則his锛堜篃灏辨槸涓€涓璞★級锛屽畠鎸囧悜璋冪敤璇ュ嚱鏁扮殑瀵硅薄銆備緥濡傪煂癴unctionprintThis(){console.log(this);}constobj={message:"I'mobj.",printThis:printThis}printThis();//鐩稿綋浜巘his.printThis();涓よ€呴兘鏄疌allingthisinthecontextofwindowpointstotheobjectthatcallsthefunction:windowobj.printThis();//杩欎釜printThis鏄湪obj鐨勪笂涓嬫枃涓皟鐢ㄧ殑锛宼his鎸囧悜璋冪敤鍑芥暟鐨勫璞★細obj鎵€浠ユ垜浠彲浠ュ仛涓€涓皬鎬荤粨锛歵his鎬绘槸鎸囧悜璋冪敤杩欎釜鍑芥暟鐨勫璞★紙object锛夈€傛瀯閫犲嚱鏁颁腑鐨則his鎸囧悜鍝噷锛熷畠鏄惁鎸囧悜璋冪敤鏋勯€犲嚱鏁扮殑瀵硅薄锛熷疄渚嬪寲瀵硅薄鏃朵細璋冪敤鏋勯€犲嚱鏁帮紝璋冪敤call()鏂规硶鎸囧悜瀵硅薄锛屾墍浠his鎸囧悜瀵硅薄鏈韩銆傝鎯呭彲浠ユ煡鐪嬪垱寤哄璞℃椂鍋氫簡鍝簺鎿嶄綔銆傛墍浠ユ垜浠彲浠ュ洖鍒版渶鍒濈殑闂锛屼负浠€涔堣浣跨敤constthat=this;锛熷父閲忛偅涓?杩欎釜锛沜onstobj={message:"I'mobj.",printThis:function(){console.log(this);},printThat:function(){console.log(that);},};obj.printThis();obj.printThat();鍏跺疄灏辨槸鎶婂閮╰his淇濆瓨鍒皌hat锛岀劧鍚庡湪鍑芥暟涓皟鐢ㄥ閮╰his銆備竴鍙ヨ瘽锛歵his灏辨槸璋冪敤杩欎釜鍑芥暟鐨勫璞★紙object锛夈€傚浣曞湪JS涓紭闆呯殑浣跨敤this鍩轰簬浠ヤ笂锛屼綘搴旇瀵箃his鏄粈涔堟湁涓€涓ぇ姒傜殑浜嗚В浜嗐€備娇鐢╟onstthat=this;杩欎釜璇彞鑲畾涓嶄紭闆咃紝閭d箞濡備綍鍦ㄩ」鐩腑浼橀泤鐨勪娇鐢ㄨ繖涓憿锛熺澶村嚱鏁板彲浠ュ厛閫氳繃绠ご鍑芥暟鐩存帴浣跨敤this锛屽洜涓虹澶村嚱鏁版病鏈夌粦瀹氭寚閽堝煙锛屼篃灏辨槸璇寸澶村嚱鏁伴噷闈㈢殑this鍜岀澶村嚱鏁板闈㈢殑this鏄竴鏍风殑銆傛帶鍒跺彴鏃ュ織锛堣繖涓級锛?/1杩欓噷鎸囧悜windowconstobj={message:"I'mobj.",printThis:function(){console.log(this);},printThisWithArrowFunction:()=>{console.鏃ュ織锛堣繖涓級锛泒}obj.printThis();//杩欓噷鐨?鎸囧悜objobj.printThisWithArrowFunction();//杩欓噷鐨?鍜?涓€鏍锋寚鍚憌indow锛屾墍浠ュ彲浠ョ敤绠ご鍑芥暟鎰夊揩鐨勮В鍐硉his鎸囧悜涓嶅悓鐨勯棶棰樸€傛墜鍔ㄦ洿鏀瑰嚱鏁扮殑thisJS涓殑鍑芥暟鎻愪緵浜嗕笁绉嶆柟娉曟潵鎵嬪姩璁剧疆this鐨勬寚鍚戯細call()銆乤pply()鍜宐ind()銆傞€氳繃璋冪敤杩欎笁涓柟娉曢棿鎺ヨ皟鐢ㄥ嚱鏁帮紝灏卞彲浠ョ洿鎺ユ寚瀹歵his浜嗭紝閭d负浠€涔堣鐢ㄤ笁涓柟娉曟寚瀹歵his鍛紵|鏂规硶|鍙傛暟|杩斿洖鍊紎璇存槑|鍛煎彨锛堬級|杩欎釜锛宲aram1锛宲aram2锛?..|鏈畾涔墊浼犲叆this鎸囬拡鍜屽弬鏁拌皟鐢▅鐢宠锛堬級|]|鏈畾涔墊璋冪敤this鎸囬拡鍜屾暟缁勫弬鏁版潵璋冪敤|缁戝畾()|杩欎釜锛宲aram1锛宲aram2锛?..|鍑芥暟鐨勫姛鑳藉嚑涔庣浉鍚岋紝鍙槸鐢ㄦ硶鐣ユ湁涓嶅悓銆備緥濡傦細functionprintThis(a,b){console.log(this,a,b);}constobj={message:"I'mobj."}[printThis.call](http://printthis.call/)(obj,1,2);printThis.apply(obj,[1,2]);//鏁扮粍褰㈠紡printThis.bind(obj,1,2)();//娉ㄦ剰杩斿洖鐨勬槸涓€涓嚱鏁帮紝闇€瑕佽皟鐢ㄦ墠鑳借繑鍥炴洿澶氱殑鍊笺€傛兂蹇呭埌杩欓噷浣犲簲璇ュ濡備綍鍚堢悊浣跨敤this鏈変簡涓€涓ぇ鑷寸殑浜嗚В鍚э紵閭f湁浠€涔堢敤鍛紵杩欓噷鏈変竴涓ぇ瀹堕兘鐭ラ亾鐨勬暟缁勮鍓殑渚嬪瓙锛歝onstarr=[1,2,3];arr.slice(1);//鍒犻櫎杩欓噷绗竴涓垏鐗囦腑鐨則his浠ユ寚鍚慳rr!console銆傛棩蹇楋紙arr锛夛紱//[2,3]//閭d箞濡備綍鍒╃敤杩欎釜鐗规€ф潵鍒囧壊闈炰竴鑸殑鏁扮粍绫诲瀷鍛紵constobj={0:1,1:2,2:3,length:3//涓€瀹氳鏈塴ength灞炴€;//鐩存帴璋冪敤obj.slice(1);涓嶅厑璁告槸鍥犱负瀵硅薄鐨勫師鍨嬫病鏈夎繖涓柟娉?/鍙互閫氳繃浜轰负鏀瑰彉鍒囩墖鐨則his鎸囬拡鏉ュ疄鐜癱onsole.log([Array.prototype.slice.call](http://array.prototype.slice.call/)(obj));//浣跨敤call鏂规硶灏唗his鎸囧悜obj