美文网首页
5.16日js数组

5.16日js数组

作者: 天色见晚 | 来源:发表于2018-05-16 22:02 被阅读0次

数组的遍历

遍历:一次访问数组中的每个元素                  for(var i=0;i<arr.length;i++){ console.log(arr[i]); 输出数组中的当前元素  } 

关联数组/hash数组 

索引数组:下标为数字的数组       

关联数组:下标部位数字的数组              var zse=[];

zse['name']='张三';         

zse['age']='18';              zse['sex']='boy';             

console.log(zse);         

注:关联数组没有length属性关联数组不能用for遍历,要用for....in遍历              for(var key in hash){    key 代表关键字,即下标  hash代表数组名      }

五、数组API

1. 转字符串: 2种

1. 将数组中每个元素都转为字符串,再用逗号分隔    var str=String(arr);  

2. 将数组中每个元素都转为字符串,再用自定义下标连接每个元素 var str=arr.join("自定义连接符")    

强调:如果省略参数,默认等效于String   固定套路:     

1. 无缝拼接: arr.join("")    

2. 将单词拼接为句子: arr.join(" ")  

3. 判断空数组: arr.join("")==""  

4. 根据数组中的元素,动态生成页面元素的内容

2. 拼接和截取

拼接                                                        var newArr=arr1.concat(值1,值2,arr2,....) 

将值1,值2,以及arr2中每个元素依次拼接到arr1结尾,返回新数组。  

何时使用: 将多个元素或其他数组,拼接到当前数组上时  

强调:   1.concat无权修改原数组,只能返回新数组     所以,必须用变量接住拼接后的返回值   2.concat可打散数组类型的参数为单个元素

截取:(复制)    var subArr=arr.slice(starti,endi+1);   复制arr中starti位置开始到endi结束的元素组成子数组返回。   何时: 选取数组中指定位置的子数组时  

强调: 1. 无权修改原数组,只返回新子数组  2.含头不含尾      

3.其实可使用负数参数,表示倒数第n个

简写:1. 省略第二个参数,表示一直截取到结尾    

2. 两个都省略,表示完整复制原数组中的元素到新数组。 不能只省略第一个参数——报错

3.splice: 删除,插入,替换   删除数组中指定位置的元素:   arr.splice(starti,n):     删除arr中starti位置开始的n个元素  其      实: var deletes=arr.splice(starti,n)    deletes: 返回的被删除的元素组成的临时子数组。  

在数组指定位置插入新元素:  arr.splice(starti,0,值1,值2,...)  在starti位置插入新值    原starti位置的值被向后顺移   强调: splice,不支持打散数组参数   插入: splice vs concat     concat只能在开头或结尾拼接,不能中间插入。                           

但可打散数组类型参数     splice可在任意位置插入,但不可打散数组类型参数。

替换数组中指定位置的元素  arr.splice(starti,n,值1,值2,...)     先删除starti位置的n个旧元素     再在starti位置插入新值 强调: 删除的个数和插入的个数不必一致  splice可自动调节数组的长度和位置    

翻转: arr.reverse();               

六、数组排序  arr.sort();  var arr=[2,4,3,5,1]; var str=arr.sort();        console.log(str);             

输出后是12345   

像以下这种函数用arr.sort无法实现排序,这时候就需要用到比较器函数  

var arr=[1,12,22,13,23,33,3,2];    function cm(a,b){  return a-b; 由小变大          return b-a;  有大变小   }      console.log(arr.sort(cm));

相关文章

  • js 数组链接concat,和数组转字符串join,字符串转数

    js 数组链接用concat js 数组转成字符串 js 字符串转数组

  • js数组题目

    js面试题 js数组 一、按要求分割数组 将"js,数组,分类"字符串数组以/分割 for循环累加 join()把...

  • js 数组

    js 中数组的长度发生改变,数组就真的发生改变,快速清空数组就让数组长度为0js 数组的方法

  • JS数组以及数组变换

    有关数组 数组对象——一种特殊的对象JS其实没有数组,只使用对象来模拟数组 典型数组和JS数组的区别 典型数组 元...

  • 数组检测

    检测是否是数组: 数组转字符串: 字符串转换数组: js对象转换成js字符串: js字符串转换成js对象:

  • 概念集合

    JS中的数组和Arrary的区别 js中的数组就是array对象

  • JS 数组

    JS 数组是一种特殊的对象,不是真正的数组,它只##是通过对象来模拟数组。 JS 数组的定义 let arr = ...

  • javaScript的数组

    js中没有数组类型 js 中数组是以内置对象的形式存在 数组定义01 var attr = new Array('...

  • 数组

    数组的定义: js:存储多个相同类型数据 ,有序的数据;php数组 1,:索引数组,同js;声明:$arrName...

  • js笔记

    js数组 删除某个元素 js数组是否含有某个元素 判断value为undefined cookie操作

网友评论

      本文标题:5.16日js数组

      本文链接:https://www.haomeiwen.com/subject/aggmdftx.html