一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

關于javascript函數的幾個話題

1.函數對象和函數指針
函數實際上是一個可執行的對象,任何訪問函數對象的方式都是函數指針。
不論 使用哪一種方式
var a=new Function(...);
function a(...){...}
var a=function(...){...}
得到的函數名a都是一個指向函數的指針 可以用var b=a;來創建另外一個指向它的指針。
但是 它們指向同一段函數。因為函數名是一個指針,所以能夠被作為參數傳遞。
()運算符作用于一個函數指針將會執行它所在的函數,當然還會傳入參數。


2.函數直接量(函數文字量)
實際上函數直接量這個說法并不準確 但可以通俗地解釋一些用法
125 "good"是都是直接量 可以在代碼中不通過變量名使用 函數也有類似的用法
function(){...} 代表了一個函數指針的值 它指向function(){...}定義的函數
那么 (function(){...})() 就執行了這個函數 a=function(){...}就創建了這個指針的一個副本

3.函數對象的成員 
函數對象繼承自object對象 它還有自己的屬性和方法
查到的就這么多 來自vs2005的提示
f.apply(thisValue,argArray);//在thisValue對象上執行 參數由數組argArray提供
f.call(thisValue);//在thisValue對象上執行,不是沒有參數,要用參數的話直接跟在thisValue后面
f.prototype; //原型 很常見 前面也用過 不多說了。 
f.length;//參數列表的長度

f.hasOwnProperty(propertyName);//繼承自Object的方法,檢查對象是否有指定屬性
f.propertyIsEnumerable(propertyName);//繼承自Object的方法,檢查指定屬性是否能被for in枚舉出來 (除了firefox下的prototype 其他屬性都不能被枚舉)
f.toLocaleString();//繼承自Object的方法,轉換為字符串
f.toString();//繼承自Object的方法,轉換為字符串 在alert document.write等時自動調用
f.valueOf();//繼承自Object的方法,求值,對象做算術運算時自動調用,如果默認就是toString 

3.Javascript函數能訪問的范圍
Javascript函數究竟能訪問那些資源? 包括三部分:函數的作用域、this指針、參數除此之外函數無法訪問任何資源。
如果要比較清晰地理解函數 應當想像函數有三組參數:
第一組是作用域 在定義時確定 是函數定義位置決定的 暫稱為外作用域 在函數定義處可以訪問的變量和函數在函數中也可以訪問,不論調用這個函數的指針被傳遞到哪里
第二組是this 在函數被調用時確定 
  如果函數是用()調用的  它默認指向函數所屬的對象:如果函數是某個對象的成員 那么this指向這個對象,否則指向全局對象(大多數時候是window)
  如果函數是用apply或者call調用的 this指向指定的thisvalue
第三組是參數 在函數被調用時確定 在參數列表中的參數可以直接訪問 不再參數列表中的參數可以用arguments訪問

4.函數作用域的生成與訪問
函數除了能夠訪問一個作用域之外 每次執行 會生成一個新的作用域 (閉包)
此作用域之外的代碼無法訪問這一作用域的變量 此作用域內的代碼可以訪問這個作用域以及此函數定義時的作用域。

跨作用域的訪問只能通過指針。js中object是指針類型。
想要獲得指向某個作用域的指針 必須從這個作用域中把指針傳遞出來:即把此作用域中的指針類型變量的值賦給其他作用域的變量
前面所說一個函數中能夠訪問的資源包括 this 外作用域 參數 所以可以通過這種方式訪問其他作用域中的變量。
一個很bt的例子

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
最后這個例子太BT了,實際上,雖然js的function有這樣的能力,但是在使用時我們一般會有一個限制,就是閉包中訪問閉包外變量時,不應當采用有“副作用”的表達式,例如++、--或者賦值,也就是說限制閉包訪問外部域的內容僅限于“讀”和“表達式計算”,可以修改外部變量實際引用的對象的值,但是不要在閉包內修改外部變量本身的值。所以下面的例子
function c(a){
    return function(x)
    {
        return x+a++;
    }
}
通常是合法但不合理的,因為這是一個有副作用的閉包。在程序邏輯復雜的情況下這很容易導致混亂。因為這個閉包在什么時候調用是完全不確定的。這個閉包的存在使得這個函數每次調用的返回值完全不同,即使采用的是同一個參數。這顯然違背了functional“公式化”的基本原則。

不過,實際上上面這種函數倒有一個特殊用途,用來生成某些特殊的計數器 :)
所以限制也不是絕對的...

JavaScript技術關于javascript函數的幾個話題,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久看视频 | 最新亚洲国产有精品 | 欧美成人性色生活片天天看 | 99国产精品免费观看视频 | 91刺激 | 在线观看免费视频黄 | 国产精品欧美一区二区在线看 | 国产高级黄区18勿进一区二区 | 国产2021精品视频免费播放 | 精品欧美一区二区精品久久 | 国产日韩欧美一区二区三区视频 | 玖玖在线精品 | 国产在线播放免费 | 久久逼逼 | 亚洲第一视频在线播放 | 手机在线观看亚洲国产精品 | 五月天婷婷影院 | 日本理论午夜中文字幕第一页 | 久久国产精品偷 | 国产日本一区二区三区 | 激情一区 | 开心六月婷婷 | 欧美网站色 | 天堂一区二区三区精品 | 成人在色线视频在线观看免费大全 | 在线国产二区 | 天天综合五月天 | 精品乱久久 | 色婷婷综合久久久中文字幕 | 精品一二三区 | 中文字幕亚洲一区 | 日韩黄色一级毛片 | 成人观看的视频三级 | 国产免费资源高清小视频在线观看 | 黄色小视频在线免费看 | 久久国产乱子伦精品在 | 91麻豆影视| 亚洲国产一区二区三区亚瑟 | 国产乱子视频 | 色婷婷综合久久久久中文一区二区 | 综合色在线 |