站長資訊網
        最全最豐富的資訊網站

        javascript的引用數據類型是什么

        在javascript中,引用數據類型是一種數據結構,用于將數據和功能組織在一起;它也常被稱為類。引用類型的值是保存在內存中的對象(同時保存在棧內存和堆內存中);引用類型的值是按引用訪問的。

        javascript的引用數據類型是什么

        本教程操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

        數據類型指的是可以在程序中存儲和操作的值的類型,每種編程語言都有其支持的數據類型,不同的數據類型用來存儲不同的數據,例如文本、數值、圖像等。

        JavaScript 中的數據類型可以分為兩種類型:

        • 基本數據類型(值類型):字符串(String)、數字(Number)、布爾(Boolean)、空(Null)、未定義(Undefined)、Symbol;

        • 引用數據類型:對象(Object)、數組(Array)、函數(Function)。

        JavaScript引用數據類型

        引用類型

        在ECMAScript中,引用類型是一種數據結構,用于將數據和功能組織在一起(它也常被稱為類)。

        引用類型的值是保存在內存中的對象(同時保存在棧內存和堆內存中)。JavaScript 不允許直接訪問內存中的位置,因此在操作對象時,實際上是操作的對象的引用而不是實際的對象。引用類型的值按引用訪問。

        Object類型

        創建Object實例的方式有兩種。第一種是使用new操作符后跟Object構造函數,例如;

        var person = new Object();  person.name = "Nicholas";  person.age = 29;

        另一種方式是使用對象字面量表示法。 例如:

        var person = {  name : "Nicholas",  age ; 29  }

        注意:在通過對象字面量定義對象時,實際上不會調用Object構造函數。

        Array類型

        創建數組的基本方式有兩種。第一種是使用Array構造函數,例如:

        var colors = new Array();

        第二種基本方式是使用數組字面量表示法。數組字面量由一對包含數組項的方括號表示,多個數組項之間以逗號隔開,例如:

        var colors = ["red","blue","green"];

        檢測數組

        instanceof操作符假定只有一個全局執行環境。為了解決只個問題,ECMAScript 5新增了Array.isArray()方法。這個方法的目的是最終確定某個值到底是不是數組,而不管它是在哪個全局執行環境中創建的。

        轉換方法

        toLocaleString()、toString()和valueOf()方法

        所有對象都具有toLocaeString()、toString()和valueOf()方法。
        調用數組的toString()方法會返回以逗號分隔的字符串;
        調用toLocaleString( )和toString()一樣,但是該字符串與執行環境的地區對應;
        調用valueOf()返回的還是數組。

        join()方法

        join()方法只接受一個參數,即用作分隔符的字符串,然后返回包含所有數組項的字符串。

        棧方法(后進先出)

        ECMAScript為數組專門提供了push()和pop()方法,以便實現類似棧的行為。push()方法可以接受任意數量的參數,把他們逐個添加到數組末尾,并返回修改后數組的長度。pop()方法則從數組末尾一處最后一項,減少數組的length值,然后返回移除的項。

        隊列方法(先進先出)

        shift()能夠移除數組中的第一項并返回該項,同時將數組長度減一。結合使用shift()和push()方法,可以像使用隊列一樣使用數組。
        ECMAScript還為數組提供了一個unshift()方法。顧名思義,unshift()與shift()的用途相反:它能在數組前端添加任意個項并返回新數組的長度。

        重排序方法

        reverse()方法會反轉數組項的順序。
        在默認情況下,sort()方法按升序排列數組項——即最小的值位于最前面,最大的值排在最后面。為了實現排序,sort()方法會地哦啊用每個數組項的toString()轉型方法,然后比較得到的字符串,以確定如何排序。這種排序方式在很多情況下都不是最佳方案,因此sort()方法可以接收一個比較函數作為參數,以便制定哪個值位于哪個值的前面。

        reverse()和sort()方法的返回值是經過排序之后的數組

        操作方法

        concat()方法可以基于當前數組中的所有項創建一個新數組。
        slice()方法能夠基于當前數組中的一或多個項創建一個新數組。slice()方法可以接受一或者兩個參數,即要返回項的起始和結束位置。(不會改變原數組)
        splice()方法主要是向數組的中部插入值。(刪除、插入、替換)該方法改變原數組的值。

        位置方法

        ECMAScript為數組實例添加了兩個位置方法:indexOf()和lastindexOf()這兩個方法都返回要查找的項在數組中的位置,或者在沒有找到的情況下返回-1。這兩個方法都接受兩個參數:要查找的項和表示查找起點位置的索引(可選的)。

        迭代方法

        ECMAScript為數組定義了五個迭代方法:

        every():對數組中的每一項運行給定函數,如果該函數對每一項都返回 true,則返回 true。
        filter():對數組中的每一項運行給定函數,返回該函數會返回 true 的項組成的數組。
        forEach():對數組中的每一項運行給定函數。這個方法沒有返回值。
        map():對數組中的每一項運行給定函數,返回每次函數調用的結果組成的數組。
        some():對數組中的每一項運行給定函數,如果該函數對任一項返回 true,則返回 true。

        歸并方法

        ECMAScript 5 還新增了兩個歸并數組的方法:reduce()和 reduceRight()。這兩個方法都會迭代數組的所有項,然后構建一個最終返回的值。
        使用 reduce()和reduceRight()方法可以執行求數組中所有值之和的操作,比如:
        var values = [1,2,3,4,5];
        var sum = values.reduce(function(prev, cur, index, array){
        return prev + cur;
        });
        alert(sum); //15

        Date類型

        創建日期對象,使用new操作符和Date構造函數即可:
        var now = new Date();
        在調用Date構造函數而不傳遞參數的情況下,新創建的對象自動獲得當前日期和時間。 為了可以接受表示日期的字符串參數,ECMAScript提供了兩個方法:Date.parse()和Date.UTC()。
        ECMAScript添加了Date.now()方法,返回表示調用這個方法時的日期和時間的毫秒數。

        繼承的方法

        Date類型也重寫了toLocaleString()、toString()和valueOf()方法。
        toLocaleString()方法會按照與瀏覽器相適應的格式返回日期與時間,而toString()方法則通常返回帶有時區信息的日期和時間。至于valueOf()方法,則根本不返回字符串,而是返回日期的毫秒表示。

        Function類型

        函數實際上是對象,函數名實際上也是一個指向函數對象的指針,不會與某個函數綁定。每個函數都是Function類型的實例,而且都與其他引用類型一樣具有屬性和方法。
        函數通常是使用函數聲明語法定義的:(函數聲明提升)

        function sum (sum1,sum2) {  return sum1 + sum2;  }

        還有一種方式,使用函數表達式定義函數:

        var sum = function(sum1,sum2) {  return sum1 +sum2 ;  };

        注意:要訪問函數指針而不執行函數的話,必須去掉函數名后面的圓括號。

        函數內部屬性

        在函數內部,有兩個特殊的對象:arguments和this。arguments是一個類數組對象,包含著傳入函數中的所有參數。該對象有一個屬性,該屬性有一個指針,指向擁有這個arguments對象的函數。this引用的是函數據以執行的環境對象。(當在網頁的全局作用域中調用函數時,this對象引用的就是window)

        函數屬性和方法

        屬性

        每個函數都包含兩個屬性:length和prototype。
        length屬性表示函數希望接收的命名參數的個數。
        對于ECMAScript中的引用類型而言,prototype是保存它們所有實例方法的真正所在。prototype屬性是不可枚舉的,所以使用for-in無效。

        方法

        每個函數都包含兩個非繼承而來的方法:apply()和call()
        這兩個方法的用途都是在特定的作用域中調用函數,實際上等于設置函數體內this對象的值。作用實例:1.傳遞參數 2.擴充函數賴以運行的作用域
        EAMAScript還定義了一個方法:bind()
        這個方法會創建一個函數的實例,其this值會被綁定到傳給bind()函數的值。
        每個函數繼承的toLocaleString()、toString()和valueOf()方法始終都返回函數的代碼。

        對象

        對象是某個特定引用類型的實例。新對象是使用new操作符后跟一個構造函數來創建的。

        new

        new運算符的作用是創建一個對象實例。這個對象可以是用戶自定義的,也可以是帶構造函數的一些系統自帶的對象。如果 new 表達式之后的構造函數返回的不是JavaScript內置的引用對象(Object,String等)new會創建一個匿名對象并返回;如果是內置引用對象或者原始類型就會覆蓋匿名對象。(無 return 時其實為 return 原始類型 undefined)

        構造函數

        構造函數本身就是一個函數,只不過該函數是出于創建新對象的目的而定義的。

        JavaScript中object和Object的區別

        object

        使用typeof檢測數據類型的時候,只要檢查的變量是一個對象,或者是null,那么它就會返回object。

        Object

        Object 是 JavaScript 中一個重要的對象,其它對象都是基于它的,包括你創建的函數。

        typeof 操作符和 instanceof 操作符的區別

        確定一個值是哪種基本類型可以使用 typeof操作符,而確定一個值是哪種引用類型可以使用instanceof操作符。

        function和Function

        ECMAScript 的Function實際上就是一個功能完整的對象。而function這個關鍵字是用來創建所有對象的構造函數或者使用關鍵字來定義普通函數的類和對象,var a=new function(){}實際上是用構造函數的方法創建了一個匿名對象的實例,而并不是系統內置對象Function的實例。所以a instanceof Function返回false,typeof返回"object"。

        什么時候typeof返回"function"呢?

        function a (){ }  //undefined  typeof a  //"function"

        【推薦學習:javascript高級教程】

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品自产拍高潮在线观看| 久久久久这里只有精品 | 国产午夜精品久久久久九九电影| 麻豆成人久久精品二区三区免费 | 国产精品H片在线播放| 精品国精品国产自在久国产应用| 人人妻人人澡人人爽精品欧美 | 国产精品扒开腿做爽爽爽视频| 欧美日韩精品久久久免费观看| 国产99久久九九精品无码| 99久久精品午夜一区二区| 麻豆国产在线精品国偷产拍| 亚洲一区无码精品色| 日本精品视频在线观看| 国产网红主播无码精品| 国产精品一区二区三区99 | 亚洲精品456播放| 久久精品国产亚洲一区二区三区| 91亚洲国产成人久久精品网址 | 鲸鱼传媒绿头鱼实验室之炮机测评日韩精品一级毛 | 91精品国产自产在线老师啪| 97国产精品视频| 成人国内精品久久久久影院 | 精品国产一区二区三区2021| 国产精品 羞羞答答在线 | 国产在线精品一区二区中文| 日产精品久久久久久久性色| 亚洲国产成人精品无码区在线观看 | 亚洲av无码乱码国产精品| 亚洲国产精品无码专区| 日韩精品区一区二区三VR| 久久精品夜夜夜夜夜久久| 国内精品久久久久久99| 国产成人精品优优av| 国产第一福利精品导航| 欧美一区二区精品久久| 91久久福利国产成人精品| 国产精品女同一区二区久久| 国产精品无码无卡无需播放器| 国产在线精品一区二区夜色 | 国产69精品久久久久9999|