摘要:所以在中,只能變通用方法復制擴展運算符三個點復制數組對象中的擴展運算符可以這樣理解對象中的擴展運算符用于取出參數對象中所有可遍歷的屬性,拷貝到當前對象中。注和擴展運算符,對一級屬于屬于深拷貝,對后面對級別屬于淺拷貝。
1. ES5定義常量
ES5中通過改變屬性描述符來達到常量的效果,我們可以將屬性定義為只讀。
Object.defineProperty(window,"PI",{ value:"3.14", writable:false })2. ES6定義常量
使用const定義
const PI = 3;3. ES5復制數組
數組是復合的數據類型,若直接復制,只是復制了指向底層數據結構的指針,而不是克隆一個全新的數組。
var arr = [1,2]; var arr2 = arr; arr2[0] = 90; console.log(arr); //[90,2] console.log(arr2) //[90,2]
所以在ES5中,只能變通用concat方法復制
var arr = [1,2]; var arr2 = arr.concat(); arr2[0] = 10; console.log(arr); //[1,2] console.log(arr2); //[10,2]4. ES6擴展運算符 ... (三個點)復制數組
對象中的擴展運算符可以這樣理解:對象中的擴展運算符(...)用于取出參數對象中所有可遍歷的屬性,拷貝到當前對象中。
let arr = [1,2,3]; let arr2 = [...arr]; // [1,2,3]
假如給拷貝arr2時push一個元素:
let arr2 = [...arr,5]; console.log(arr2); //[1,2,3,5] console.log(arr); //[1,2,3]
可以看到只會改變arr2的值,而不會影響arr的值。同樣改變arr的值也不會影響到arr2的值。
arr.push(12); console.log(arr); //[1,2,3,12] console.log(arr2); //[1,2,3,5]
所以,上述方法實際上等價于:
let arr = [1,2,3]; let arr2 = Object.assign([],arr); console.log(arr2); //[1,2,3] arr2.push(12); console.log(arr2); //[1,2,3,12] console.log(arr); //[1,2,3]
Object.assign方法用于對象的合并,將源對象所有的可枚舉屬性復制到目標對象。
注:Object.assign和擴展運算符(...),對一級屬于屬于深拷貝,對后面對級別屬于淺拷貝。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/109542.html
摘要:用來表示與大于的最小浮點數之間的差,實際上就是能夠表示的最小精度。對象的擴展在對象上新增了個與數學相關的方法。用于去除一個數的小樹部分,返回整數部分。對于非數值,則用方法將其轉換為數值,對于空值和無法截取整數的值,返回。返回以為底的的對數。 showImg(https://segmentfault.com/img/bVbrTG6?w=1080&h=1080); 1. 二進制和八進制表示...
摘要:用來表示與大于的最小浮點數之間的差,實際上就是能夠表示的最小精度。對象的擴展在對象上新增了個與數學相關的方法。用于去除一個數的小樹部分,返回整數部分。對于非數值,則用方法將其轉換為數值,對于空值和無法截取整數的值,返回。返回以為底的的對數。 showImg(https://segmentfault.com/img/bVbrTG6?w=1080&h=1080); 1. 二進制和八進制表示...
摘要:函數調用會在內存形成一個調用記錄,又稱調用幀,保存調用位置和內部變量等信息。等到運行結束,將結果返回到,的調用幀才會消失。方法用于將一組值,轉換為數組。,和遍歷數組方法返回一個布爾值,表示某個數組是否包含給定的值,與字符串的方法類似。 ES6 簡介 ES6, 全稱 ECMAScript 6.0 ,是 JavaScript 的下一個版本標準,2015.06 發版。 let 和 const...
閱讀 1804·2023-04-26 02:32
閱讀 567·2021-11-18 13:12
閱讀 2446·2021-10-20 13:48
閱讀 2514·2021-10-14 09:43
閱讀 3825·2021-10-11 10:58
閱讀 3481·2021-09-30 10:00
閱讀 2931·2019-08-30 15:53
閱讀 3486·2019-08-30 15:53