日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

javascript高程3 学习笔记(三)

發布時間:2023/12/4 javascript 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 javascript高程3 学习笔记(三) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

執行環境

執行環境是什么?

  • javascript的解釋器每次開始執行一個函數時,都會為每個函數創建一個執行環境(execution context)。
  • 執行環境定義了變量或者函數有權訪問的其他數據,決定了他們各自的行為。
  • 與執行環境相關的變量對象(ariable object)中有執行環境定義的所有變量和函數

作用域鏈

  • 代碼在一個環境中執行,便會創建變量對象的一個作用域鏈(scope chain)。
  • 作用域鏈的作用是,保證對執行環境有權訪問的所有變量和函數的有序訪問
  • 如果環境是函數,則其活動對象(active object)為環境變量
  • 活動對象最開始含有一個變量,名為arguments對象(該變量全局中不存在)
  • 作用域鏈的下一個對象來自包含對象,再下一個對象來自下一個包含環境...
  • 標識符的解析是沿著作用域鏈逐級向上搜索標識符的過程
  • 通過try catch/with 來延長作用域
  • 沒有塊級作用域(類C的花括號)

代碼示例

var color = "blue";function changeColor(){if(color == "blue"){color = "red";}else{color = "blue";} } changeColor(); alert(color); // red var color = "blue";function changeColor(){var anotherColor = "red";function swapColor(){var tempColor = anotherColor;anotherColor = color;color = tempColor;// 能訪問 color和anotherColor,tempColor} // 能訪問 color和anotherColorswapColor();alert(color);alert(anotherColor); } // 能訪問 color changeColor(); alert(color); alert(anotherColor); //不能被訪問到 undefined<pre><code><br />####js 垃圾回收 Garbage Collection(GC) &gt; - javascript具有自動垃圾回收機制 - 兩種策略,標記清除和引用計數 ?- 標記清除(較為常見),第一遍標記所有變量,第二次標記待清除變量 - 引用計數,通過檢測變量引用次數的值判定是否變量可以被回收,問題是存在循環引用問題####Function 類型 &gt; - 每個函數都是Function類型的實例 - 函數是對象,具有屬性和方法,函數名實際上便是指向函數對象的指針 - 函數定義的三種方式 - 函數沒有重載,后定義的會覆蓋之前的 - 將函數名作為變量進行傳參 - 函數的兩個內部屬性**`arguments`**和**`this`**還有一個**`caller`** - 函數的屬性(有個疑問,和內部屬性什么區別么),兩個`length`(參數個數)和`prototype` - 兩個非繼承方法`apply()` `call()`####代碼示例 *函數的三種定義方式* </code></pre>// 函數定義的三種方式 // 函數聲明 function sum(num1,num2){return num1 + num2; }// 函數表達式 var sum = function(num1,num2){return num1 + num2; };// 使用Function構造函數 兩次代碼解析性能慢 不推薦 var sum = new Function("num1","num2","return num1 + num2");<pre><code>?*函數聲明提升(function declaration hositing)* </code></pre>// 可以訪問sum alert(sum(10,10)); function sum(num1,num2){return num1 + num2; }// 函數表達式則不行 alert(sum1(10,10)); var sum1 = function(num1,num2){return num1 + num2; }<pre><code>這是因為解析器在向執行環境加載數據時候,對于函數聲明和函數表達式,解析器會率先讀取函數聲明,使其在任何代碼之前可用(可以訪問) *作為值的函數,函數名做為變量進行傳參* </code></pre>function callSomeFunction(someFunction,someArgument){return someFunction(someArgument); }function add10(num1){return num1 + 10; }var result = callSomeFunction(add10,10); alert(result);<pre><code><br />*函數的內部屬性* arguments對象上一篇筆記提及,類數組對象包含傳入函數的所有參數 arguments對象擁有一個名為 `callee`的屬性,該屬性是一個指針,指向arguments對象的函數 它的作用: </code></pre>function factorial(num){if(num <= 1){return 1;}else{// return num * factorial(num - 1);return num * arguments.callee(num - 1);} }var trueFactorial = factorial; factorial = function(){return 0; } alert(trueFactorial(5)); // 120 alert(factorial(5)); // 0<pre><code>`callee`作為指針的用法,解除了函數體內代碼和函數名的耦合 **`this`**(很重要,要理解掌握) this引用的是函數據以執行的環境對象或者說是this值(全局作用域調用函數時,this指向的引用就是window) </code></pre>window.color = "red";var o = {color:"blue" }; function sayColor(){alert(this.color); }sayColor();o.sayColor = sayColor; // 函數名是指向函數的指針 o.sayColor();<pre><code>可以通過調試代碼,查看當前所在的this指向的環境對象 **疑問:如果window.color 直接寫color/var color,不是應該也是指向全局的么,為什么會報undefined***兩個非繼承的方法apply() call()* </code></pre>// apply() call() bind() function sum(num1,num2){return num1 + num2; }function applySum(num1,num2){return sum.apply(this,arguments); // 傳入arguments// return sum.call(this,[num1,num2]; //或者傳入數組 } alert(callSum(10,10)); function callSum(num1,num2){return sum.call(this,num1,num2); } alert(callSum(10,10));<pre><code>?*apply()和call() 的作用在于 擴充函數作用域(不明覺厲)* </code></pre>window.color = "red"; var o = {color:"blue" }; function sayColor(){alert(this.color); }var objectSayColor = sayColor.bind(o); // bind方法 傳入對象o objectSayColor();sayColor(); sayColor.call(this); sayColor.call(window); sayColor.call(o);

小結

  • 執行環境的概念
  • 什么是作用域,作用域鏈的作用
  • 函數是個對象,有相應的屬性和方法
  • 前面的哪個疑問 是什么原因?
  • 總結

    以上是生活随笔為你收集整理的javascript高程3 学习笔记(三)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 免费特级毛片 | 亚洲自拍偷拍综合 | 国产精品九九 | 精品国产露脸精彩对白 | 久久精品在线观看 | 久久综合伊人77777麻豆 | 99久热在线精品996热是什么 | 国产三极片 | jzzijzzij日本成熟少妇 | 久久亚洲av午夜福利精品一区 | 日韩第四页 | 污网站在线观看免费 | 亚洲s码欧洲m码国产av | 亚洲片在线观看 | 国产小视频一区 | 97久久国产亚洲精品超碰热 | 色倩网站 | 色婷婷激情 | av鲁丝一区二区鲁丝 | 丁香花电影在线观看免费高清 | 久久久无码一区二区三区 | 国产精品免费观看视频 | 樱空桃在线| 日韩激情四射 | 一区二区三区视频在线 | 成了校长的性脔h文 | 中文字幕日韩欧美一区二区 | 亚洲a精品 | 特级淫片裸体免费看冫 | 免费看60分钟黄视频 | 免费在线观看中文字幕 | 妻子的性幻想 | 初尝人妻少妇中文字幕 | 有码在线视频 | 神马久久久久久 | 朝桐光av在线 | 欧美少妇xxxxx | 奇米狠狠干 | 亚欧洲精品在线视频免费观看 | 综合天堂av久久久久久久 | 久操国产视频 | 涩久久| 美女张开双腿让男人捅 | 日本激情一区 | 91淫黄大片 | 欧美日韩国产精品一区二区三区 | 中文字幕精品在线视频 | 中文字幕在线观看你懂的 | 国产第一毛片 | 久久久久久蜜桃一区二区 | 在线观看免费的av | 少妇一级淫片免费放中国 | 精品动漫一区二区三区的观看方式 | 国产一区免费在线观看 | 国产视频1区2区3区 国产欧美一区二区精品性色99 | 最新av女优 | 成人黄色免费在线观看 | 蜜臀少妇久久久久久久高潮 | 天天干天天拍 | 日韩精品在线观看视频 | 亚洲品质自拍 | 欧美极品少妇xxxxⅹ喷水 | 成人久久毛片 | 欧洲国产视频 | 免费一级片网址 | 亚洲精品日本 | 日韩性xxx | 国产成人自拍视频在线观看 | www.浪潮av.com | 欧美综合一区 | 成人在线免费看片 | 91成人福利 | 尤物网站在线 | 强伦人妻一区二区三区视频18 | 欧美成综合 | 91av久久| 一级片免费看视频 | 超碰午夜 | 一本在线免费视频 | 超碰人人网| 风韵少妇spa私密视频 | 95香蕉视频| 久久久久女 | 国产一区二区三区久久久 | 蜜臀av夜夜澡人人爽人人 | av观看网| 操日本老太太 | 欧美日韩亚洲精品内裤 | 日韩伦理av | 亚洲性少妇 | 自拍日韩亚洲一区在线 | 第四色影音先锋 | 欧美一区二区三区国产 | 欧美激情久久久久久 | 97xxx| av大片免费观看 | 91看片成人 | 精久久 | 99热在线只有精品 |