实战IT培训机构_IT培训班选大学生IT技术培训中心_中公优就业

400-650-7353
您所在的位置:首頁 > IT干貨資料 > web前端 > 【Web前端基礎知識】Array數組函數實例方法

【Web前端基礎知識】Array數組函數實例方法

  • 發布: Web前端培訓
  • 來源:Web前端培訓問答
  • 2021-02-25 10:31:21
  • 閱讀()
  • 分享
  • 手機端入口

valueOf(),toString()

valueOf方法是一個所有對象都擁有的方法,表示對該對象求值。不同對象的valueOf方法不盡一致,數組的valueOf方法返回數組本身。

toString方法也是對象的通用方法,數組的toString方法返回數組的字符串形式。

  1. var arr = [1, 2, 3]; 
  2. arr.toString() // "1,2,3" 

push(),pop()

push方法用于在數組的末端添加一個或多個元素,并返回添加新元素后的數組長度。注意,該方法會改變原數組。

  1. var arr = []; 
  2. arr.push(1);  
  3. arr.push('a'); 
  4. arr.push(true, {})  
  5. console.log(arr); // [1, 'a', true, {}] 

上面代碼使用push方法,往數組中添加了四個成員。

pop方法用于刪除數組的最后一個元素,并返回該元素。注意,該方法會改變原數組。

  1. var arr = [1, 2, 3]; 
  2. ​ 
  3. console.log(arr.pop()); // 3 
  4. console.log(arr); // ['a', 'b'] 

對空數組使用pop方法,不會報錯,而是返回undefined。

shift(),unshift()

shift()方法用于刪除數組的第一個元素,并返回該元素。注意,該方法會改變原數組。

  1. var arr = ['a', 'b', 'c']; 
  2. arr.shift(); // 'a' 
  3. arr; // ['b', 'c'] 

上面代碼中,使用shift()方法以后,原數組就變了。

unshift()方法用于在數組的第一個位置添加元素,并返回添加新元素后的數組長度。注意,該方法會改變原數組。

  1. var arr = ['a', 'b', 'c']; 
  2. arr.unshift('x'); // 4 
  3. arr; // ['x', 'a', 'b', 'c'] 

unshift()方法可以接受多個參數,這些參數都會添加到目標數組頭部。

  1. var arr = [ 'c', 'd' ]; 
  2. arr.unshift('a', 'b') // 4 
  3. arr // [ 'a', 'b', 'c', 'd' ] 

join()

join()方法以指定參數作為分隔符,將所有數組成員連接為一個字符串返回。如果不提供參數,默認用逗號分隔。

  1. var a = [1, 2, 3, 4]; 
  2. a.join(' ') // '1 2 3 4' 
  3. a.join(' | ') // "1 | 2 | 3 | 4" 
  4. a.join() // "1,2,3,4" 

concat()

concat方法用于多個數組的合并。它將新數組的成員,添加到原數組成員的后部,然后返回一個新數組,原數組不變。

  1. ['hello'].concat(['world']); // ["hello", "world"] 
  2. ['hello'].concat(['world'], ['!']);// ["hello", "world", "!"] 

除了數組作為參數,concat也接受其他類型的值作為參數,添加到目標數組尾部。

  1. [1, 2, 3].concat(4, 5, 6); // [1, 2, 3, 4, 5, 6] 

reverse()

reverse方法用于顛倒排列數組元素,返回改變后的數組。注意,該方法將改變原數組。

  1. var a = ['a', 'b', 'c']; 
  2. a.reverse(); // ["c", "b", "a"] 
  3. a; // ["c", "b", "a"] 

slice()

slice()方法用于提取目標數組的一部分,返回一個新數組,原數組不變。 arr.slice(start, end);

它的第一個參數為起始位置(從0開始,會包括在返回的新數組之中),第二個參數為終止位置(但該位置的元素本身不包括在內)。如果省略第二個參數,則一直返回到原數組的最后一個成員。

  1. var a = ['a', 'b', 'c']; 
  2. a.slice(0); // ["a", "b", "c"] 
  3. a.slice(1); // ["b", "c"] 
  4. a.slice(1, 2); // ["b"] 
  5. a.slice(2, 6); // ["c"] 
  6. a.slice(); // ["a", "b", "c"] 

如果slice()方法的參數是負數,則表示倒數計算的位置。

splice()

splice()方法用于刪除原數組的一部分成員,并可以在刪除的位置添加新的數組成員,返回值是被刪除的元素。注意,該方法會改變原數組。arr.splice(start, count, addElement1, addElement2, ...);

splice的第一個參數是刪除的起始位置(從0開始),第二個參數是被刪除的元素個數。如果后面還有更多的參數,則表示這些就是要被插入數組的新元素。

  1. var a = ['a', 'b', 'c', 'd', 'e', 'f']; 
  2. a.splice(4, 2); // ["e", "f"] 
  3. a; // ["a", "b", "c", "d"] 

上面代碼從原數組4號位置,刪除了兩個數組成員。

  1. var a = ['a', 'b', 'c', 'd', 'e', 'f']; 
  2. a.splice(4, 2, 1, 2); // ["e", "f"] 
  3. a; // ["a", "b", "c", "d", 1, 2] 

上面代碼除了刪除成員,還插入了兩個新成員。

起始位置如果是負數,就表示從倒數位置開始刪除。

  1. var a = ['a', 'b', 'c', 'd', 'e', 'f']; 
  2. a.splice(-4, 2); // ["c", "d"] 

上面代碼表示,從倒數第四個位置c開始刪除兩個成員。

如果只是單純地插入元素,splice方法的第二個參數可以設為0。

  1. var a = [1, 1, 1]; 
  2. a.splice(1, 0, 2); // [] 
  3. a; // [1, 2, 1, 1] 

如果只提供第一個參數,等同于將原數組在指定位置拆分成兩個數組。

  1. var a = [1, 2, 3, 4]; 
  2. a.splice(2); // [3, 4] 
  3. a; // [1, 2] 

sort()

sort方法對數組成員進行排序,默認是按照字典順序排序。排序后,原數組將被改變。

  1. ['d', 'c', 'b', 'a'].sort() 
  2. // ['a', 'b', 'c', 'd'] 
  3.  
  4. [4, 3, 2, 1].sort() 
  5. // [1, 2, 3, 4] 
  6.  
  7. [11, 101].sort() 
  8. // [101, 11] 
  9.  
  10. [10111, 1101, 111].sort() 
  11. // [10111, 1101, 111] 

上面代碼的最后兩個例子,需要特殊注意。sort()方法不是按照大小排序,而是按照字典順序。也就是說,數值會被先轉成字符串,再按照字典順序進行比較,所以101排在11的前面。

如果想讓sort方法按照自定義方式排序,可以傳入一個函數作為參數。

  1. [10111, 1101, 111].sort(function (a, b) { 
  2.   return a - b; 
  3. }) 
  4. // [111, 1101, 10111] 

上面代碼中,sort的參數函數本身接受兩個參數,表示進行比較的兩個數組成員。如果該函數的返回值大于0,表示第一個成員排在第二個成員后面;其他情況下,都是第一個元素排在第二個元素前面。

  1.   { name: "張三", age: 30 }, 
  2.   { name: "李四", age: 24 }, 
  3.   { name: "王五", age: 28  } 
  4. ].sort(function (o1, o2) { 
  5.   return o1.age - o2.age; 
  6. }) 
  7. // [ 
  8. //   { name: "李四", age: 24 }, 
  9. //   { name: "王五", age: 28  }, 
  10. //   { name: "張三", age: 30 } 
  11. // ] 

注意,自定義的排序函數應該返回數值,否則不同的瀏覽器可能有不同的實現,不能保證結果都一致。

以上是對數組創建方式和常用方法的描述,希望可以讓你對數組有清晰的了解。

文章“【Web前端基礎知識】Array數組函數實例方法”已幫助

>>本文地址:http://www.jecan.cn/zhuanye/2021/67119.html

THE END  

聲明:本站稿件版權均屬中公教育優就業所有,未經許可不得擅自轉載。

1 您的年齡

2 您的學歷

3 您更想做哪個方向的工作?

獲取測試結果
  • 大前端大前端
  • 大數據大數據
  • 互聯網營銷互聯網營銷
  • JavaJava
  • Linux云計算Linux
  • Python+人工智能Python
  • 嵌入式物聯網嵌入式
  • 全域電商運營全域電商運營
  • 軟件測試軟件測試
  • 室內設計室內設計
  • 平面設計平面設計
  • 電商設計電商設計
  • 網頁設計網頁設計
  • 全鏈路UI/UE設計UI設計
  • VR/AR游戲開發VR/AR
  • 網絡安全網絡安全
  • 新媒體與短視頻運營新媒體
  • 直播帶貨直播帶貨
  • 智能機器人軟件開發智能機器人
 

快速通道fast track

近期開班時間TIME

主站蜘蛛池模板: 仓储货架_南京货架_钢制托盘_仓储笼_隔离网_环球零件盒_诺力液压车_货架-南京一品仓储设备制造公司 | LED显示屏_LED屏方案设计精准报价专业安装丨四川诺显科技 | 慢回弹测试仪-落球回弹测试仪-北京冠测精电仪器设备有限公司 | 阴离子_阳离子聚丙烯酰胺厂家_聚合氯化铝价格_水处理絮凝剂_巩义市江源净水材料有限公司 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | 抓斗式清污机|螺杆式|卷扬式启闭机|底轴驱动钢坝|污水处理闸门-方源水利机械 | 上海风淋室_上海风淋室厂家_上海风淋室价格_上海伯淋 | 开业庆典_舞龙舞狮_乔迁奠基仪式_开工仪式-神挚龙狮鼓乐文化传媒 | 天津云仓-天津仓储物流-天津云仓一件代发-顺东云仓 | 变位机,焊接变位机,焊接变位器,小型变位机,小型焊接变位机-济南上弘机电设备有限公司 | 磁力轮,磁力联轴器,磁齿轮,钕铁硼磁铁-北京磁运达厂家 | 反渗透水处理设备|工业零排放|水厂设备|软化水设备|海南净水设备--海南水处理设备厂家 | 柔软云母板-硬质-水位计云母片组件-首页-武汉长丰云母绝缘材料有限公司 | 植筋胶-粘钢胶-碳纤维布-碳纤维板-环氧砂浆-加固材料生产厂家-上海巧力建筑科技有限公司 | 深圳展厅设计_企业展馆设计_展厅设计公司_数字展厅设计_深圳百艺堂 | 锂电混合机-新能源混合机-正极材料混料机-高镍,三元材料混料机-负极,包覆混合机-贝尔专业混合混料搅拌机械系统设备厂家 | 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 | 硬齿面减速机[型号全],ZQ减速机-淄博久增机械 | 塑胶跑道_学校塑胶跑道_塑胶球场_运动场材料厂家_中国塑胶跑道十大生产厂家_混合型塑胶跑道_透气型塑胶跑道-广东绿晨体育设施有限公司 | 东莞市天进机械有限公司-钉箱机-粘箱机-糊箱机-打钉机认准东莞天进机械-厂家直供更放心! | 青岛球场围网,青岛车间隔离网,青岛机器人围栏,青岛水源地围网,青岛围网,青岛隔离栅-青岛晟腾金属制品有限公司 | 手持气象站_便携式气象站_农业气象站_负氧离子监测站-山东万象环境 | 并网柜,汇流箱,电控设备,中高低压开关柜,电气电力成套设备,PLC控制设备订制厂家,江苏昌伟业新能源科技有限公司 | 通辽信息港 - 免费发布房产、招聘、求职、二手、商铺等信息 www.tlxxg.net | 高速龙门架厂家_监控杆_多功能灯杆_信号灯杆_锂电池太阳能路灯-鑫世源照明 | 电子万能试验机_液压拉力试验机_冲击疲劳试验机_材料试验机厂家-济南众标仪器设备有限公司 | 螺杆泵_中成泵业 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | sus630/303cu不锈钢棒,440C/430F/17-4ph不锈钢研磨棒-江苏德镍金属科技有限公司 | 二氧化碳/活性炭投加系统,次氯酸钠发生器,紫外线消毒设备|广州新奥 | 蜗轮丝杆升降机-螺旋升降机-丝杠升降机厂家-润驰传动 | 小型数控车床-数控车床厂家-双头数控车床 | 直齿驱动-新型回转驱动和回转支承解决方案提供商-不二传动 | 电解抛光加工_不锈钢电解抛光_常州安谱金属制品有限公司 | 北京模型公司-军事模型-工业模型制作-北京百艺模型沙盘公司 | 国资灵活用工平台_全国灵活用工平台前十名-灵活用工结算小帮手 | 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 | 隐形纱窗|防护纱窗|金刚网防盗纱窗|韦柏纱窗|上海青木装潢制品有限公司|纱窗国标起草单位 | 广州企亚 - 数码直喷、白墨印花、源头厂家、透气无手感方案服务商! | 网站建设,北京网站建设,北京网站建设公司,网站系统开发,北京网站制作公司,响应式网站,做网站公司,海淀做网站,朝阳做网站,昌平做网站,建站公司 | 施工电梯_齿条货梯_烟囱电梯_物料提升机-河南大诚机械制造有限公司 |