您好,登錄后才能下訂單哦!
這篇文章主要介紹“javascript的引用數據類型有哪些”,在日常操作中,相信很多人在javascript的引用數據類型有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”javascript的引用數據類型有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
在javascript中,引用數據類型是一種數據結構,用于將數據和功能組織在一起;它也常被稱為類。引用類型的值是保存在內存中的對象(同時保存在棧內存和堆內存中);引用類型的值是按引用訪問的。
本教程操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。
數據類型指的是可以在程序中存儲和操作的值的類型,每種編程語言都有其支持的數據類型,不同的數據類型用來存儲不同的數據,例如文本、數值、圖像等。
JavaScript 中的數據類型可以分為兩種類型:
基本數據類型(值類型):字符串(String)、數字(Number)、布爾(Boolean)、空(Null)、未定義(Undefined)、Symbol;
引用數據類型:對象(Object)、數組(Array)、函數(Function)。
在ECMAScript中,引用類型是一種數據結構,用于將數據和功能組織在一起(它也常被稱為類)。
引用類型的值是保存在內存中的對象(同時保存在棧內存和堆內存中)。JavaScript 不允許直接訪問內存中的位置,因此在操作對象時,實際上是操作的對象的引用而不是實際的對象。引用類型的值按引用訪問。
創建Object實例的方式有兩種。第一種是使用new操作符后跟Object構造函數,例如;
var person = new Object(); person.name = "Nicholas"; person.age = 29;
另一種方式是使用對象字面量表示法。 例如:
var person = { name : "Nicholas", age ; 29 }
注意:在通過對象字面量定義對象時,實際上不會調用Object構造函數。
創建數組的基本方式有兩種。第一種是使用Array構造函數,例如:
var colors = new Array();
第二種基本方式是使用數組字面量表示法。數組字面量由一對包含數組項的方括號表示,多個數組項之間以逗號隔開,例如:
var colors = ["red","blue","green"];
instanceof操作符假定只有一個全局執行環境。為了解決只個問題,ECMAScript 5新增了Array.isArray()方法。這個方法的目的是最終確定某個值到底是不是數組,而不管它是在哪個全局執行環境中創建的。
所有對象都具有toLocaeString()、toString()和valueOf()方法。
調用數組的toString()方法會返回以逗號分隔的字符串;
調用toLocaleString( )和toString()一樣,但是該字符串與執行環境的地區對應;
調用valueOf()返回的還是數組。
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
創建日期對象,使用new操作符和Date構造函數即可:
var now = new Date();
在調用Date構造函數而不傳遞參數的情況下,新創建的對象自動獲得當前日期和時間。 為了可以接受表示日期的字符串參數,ECMAScript提供了兩個方法:Date.parse()和Date.UTC()。
ECMAScript添加了Date.now()方法,返回表示調用這個方法時的日期和時間的毫秒數。
Date類型也重寫了toLocaleString()、toString()和valueOf()方法。
toLocaleString()方法會按照與瀏覽器相適應的格式返回日期與時間,而toString()方法則通常返回帶有時區信息的日期和時間。至于valueOf()方法,則根本不返回字符串,而是返回日期的毫秒表示。
函數實際上是對象,函數名實際上也是一個指向函數對象的指針,不會與某個函數綁定。每個函數都是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 表達式之后的構造函數返回的不是JavaScript內置的引用對象(Object,String等)new會創建一個匿名對象并返回;如果是內置引用對象或者原始類型就會覆蓋匿名對象。(無 return 時其實為 return 原始類型 undefined)
構造函數本身就是一個函數,只不過該函數是出于創建新對象的目的而定義的。
使用typeof檢測數據類型的時候,只要檢查的變量是一個對象,或者是null,那么它就會返回object。
Object 是 JavaScript 中一個重要的對象,其它對象都是基于它的,包括你創建的函數。
確定一個值是哪種基本類型可以使用 typeof操作符,而確定一個值是哪種引用類型可以使用instanceof操作符。
ECMAScript 的Function實際上就是一個功能完整的對象。而function這個關鍵字是用來創建所有對象的構造函數或者使用關鍵字來定義普通函數的類和對象,var a=new function(){}實際上是用構造函數的方法創建了一個匿名對象的實例,而并不是系統內置對象Function的實例。所以a instanceof Function返回false,typeof返回"object"。
什么時候typeof返回"function"呢?
function a (){ } //undefined typeof a //"function"
到此,關于“javascript的引用數據類型有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。