js数组API和字符串API汇总

原文链接

一、数组API

      1. 连接:arr.join("连接符")

      用连接符把数组里面的元素连接成字符串。

      arr.join("")能无缝连接。

   2. 拼接:arr.concat("a","b",arr1)

      强调:(1)不会修改原数组,返回新数组。

           (2)concat方法中的数组会被打散为单个元素再拼接。

   3. 截取:arr.slice(start[,end])

      强调:(1)不会修改原数组,返回新的子数组。

           (2)含头不含尾。

           (3)省略第二个参数表示从start位置开始一直截取到末尾。

           (4)支持负数,表示倒数第几个。

   4. 删除、插入、替换:arr.splice(start,n[,value1,value2...])

      强调:(1)直接修改原数组。

           (2)返回所有被删除元素组成的子数组。

           (3)如果是插入,删除了0个数,那么从start位置开始以及之后的元素会被顺移。

   5. 翻转数组:arr.reverse()

      强调:(1)直接修改原数组。

   6. 数组排序:arr.sort()

      强调:(1)直接修改原数组。

           (2)默认按照数组元素第一位的ASCII码从小到大排列。

           (3)可以设置下列的比较器函数来控制升序,降序或者打乱。

           (4)arr.sort(function(a,b){return a-b;}); 升序(只限数组中是数字或者数字字符串)。

           (5)arr.sort(function(a,b){return b-a;}); 降序(只限数组中是数字或者数字字符串)。

           (6)arr.sort(function(){

                   return Math.random()>.5 ? 1 : -1;

              });随机打乱数组(数组中可以是任何数据类型)

   7. 查找:arr.indexOf(value[,from])或arr.lastIndexOf(value[,from])

      强调:(1)返回value在数组中的位置,没有找到返回-1

   8. 是否有符合的:arr.some(function(value,index,arr){

                      return value > 7;

                  })

      强调:(1)判断数组中有没有符合条件的元素,只要遇到符合条件的就退出循环。

           (2)返回boolean值。

   9. 是否都符合:arr.every(function(value,index,arr){return value > 7;})

      强调:(1)判断数组中的元素是否都符合条件。

           (2)返回boolean值。

   10. 过滤数组:arr.filter(function(value,index,arr){return value > 7;})

       强调:(1)过滤数组,返回符合条件的元素组成的新数组。

   11. 循环数组,无返回值arr.forEach(function(value,index,arr){})

   12. 循环数组,有返回值:arr.map(function(value,index,arr){})

   13.汇总:arr.reduce(function(prev,value,index,arr){

                  return prev + value;

            })

       返回数组里面所有元素相加的和。prev是之前那些元素的和。

   14. 数组转字符串:String(arr)或arr.toString()

       将数组中的元素用逗号连接成字符串,类似于arr.join(",")。

   15. 开头入栈:arr.unshift(value)

       在数组的最开头插入元素。

       强调:(1)修改原数组。

            (2)返回新数组的length。

   16. 开头出栈:arr.shift()

       弹出数组最开头的元素。

       强调:(1)修改原数组。

            (2)返回被弹出的元素。

   17. 结尾入栈:arr.push(value1[,value2,arr1])

       在数组末尾追加元素。

       强调:(1)修改原数组。

            (2)返回新数组的length。

            (3)追加进去的数组不会被打散。

   18. 结尾出栈:arr.pop()

       弹出数组最末尾的元素。

       强调:(1)修改原数组。

            (2)返回被弹出的元素。

二、字符串API

   1. 截取:str.slice(from[,end])或str.substring(start[,end])或str.substr(start[,length])

      强调:(1)slice和substring用法类似,只是slice支持负数,而substring的负数会被转换成0,然后截取0和start之间字符。

           (2)substr的start支持负数。

   2. 分割:str.split("分割符")

      把字符串以分割符为界点分割成数组。

   3. 查找:str.indexOf(value[,from])或str.lastIndexOf(value[,from])

      强调:(1)indexOf()只查找第一个,找不到返回-1。

   4. 替换:str.replace("被替换字符","替换字符")

      强调:(1)只会替换第一个,如果要替换所有符合条件的字符可以使用正则g。

   5. 拼接:str.concat(value)

      把value拼接到str上,效果类似于str+value

   6. 获取指定位置字符:str.charAt(index)或str[index]

   7. 去掉字符串前后空格:str.trim()

   8. 字符串转ASCII:str.charCodeAt(index)

   9. ASCII字符串String.fromCharCode(Unicode)

   10. 转大写字母:str.toUpperCase()

   11. 转小写字母:str.toLowerCase()

三、4种字符串“查找”方法的对比

   1. str.indexOf(value[,from])

      强调:(1)只能查找第一个匹配的位置,没找到返回-1,可用循环改变from查找所有。

   2. str.search(reg)

      强调:(1)仅判断有没有。

           (2)只返回第一个匹配的位置,没找到返回-1。

           (3)支持正则(不支持g,支持i)。

   3. str.match(reg)

      强调:(1)返回所有正则匹配的字符串组成的数组,没找到返回null。

           (2)支持正则,正则表达式必须带g,才能返回所有匹配的字符串。

   4. reg.exec(str)

      既能找到关键词的位置,又能获得内容。

      强调:(1)支持正则,找不到返回null。

           (2)若要查找所有正则必须加g,不加g只能查找第一个,而且要放进循环里面。


  
  
  1. var str = "大5家好5,谢6谢!";
  2. var reg = /[\d]/g;
  3. console.log(str)
  4. var arr = null;
  5. while((arr = reg.exec(str)) !== null){
  6. console.log(arr)
  7. }






















猜你喜欢

转载自blog.csdn.net/weixin_43271750/article/details/84975533