截取字符串方法

方法名 参数 返回值 例子
String.prototype.substr() (indexStart, length) 都可为负数,length为负数时自动转为0,length不传默认截取剩下的所有 新字符串 'JavaScript'.substr(4, 6) // "Script"
String.prototype.substring() (indexStart, indexEnd) 负数会转为0 新字符串 'JavaScript'.substring(-4) // "JavaScript"
String.prototype.slice() (indexStart, indexEnd) 负数会转为与长度相加之后的数 新字符串 'JavaScript'.slice(-4) // "ript"

三者区别:

  • 他们三者第二个参数都是可选的,如果只传一个正常下标的数字,都是返回从这个下标开始到字符串结束的这一段字符串,他们都不会改变原字符串
  • substr截取的是从indexStart下标开始长度为length的字符串,substring和slice两个参数都是开始和结束的下标,并且都不包含结束下标的字符
  • substring和slice参数如果为负数,substring会转为0,而slice会转为与字符串的长度相加之后的新下标

截取数组方法

方法名 参数 返回值 例子
Array.prototype.slice() (indexStart, indexEnd) 如果slice方法的参数是负数,则表示倒数计算的位置 新数组 ['a', 'b', 'c'].slice(1, 2) //['b']
Array.prototype.splice() (indexStart, count, addElement1, addElement2,...) 如果只传一个参数就相当于把原数组拆分为截断了 被删除的元素,改变原数组 ['a', 'b', 'c', 'd', 'e', 'f'].splice(4, 2); // ["e", "f"]

两者区别:

  • 只传一个正常下标,都能得到从这个下标开始到数组结束的一个新数组
  • slice不会改变原数组,返回值是新数组,splice会改变,返回值是被删除的元素
  • slice能够删除原数组中的某些元素,并能在删除的位置添加新成员

tips:

  • slice方法还有一个重要的应用,可以将类数组对象转为数组
    Array.prototype.slice.call({ 0: 'a', 1: 'b', length: 2 })  //['a', 'b']
  • Array.from也可以做到
    Array.from({ 0: 'a', 1: 'b', length: 2 })  //['a', 'b']

常用数组方法

var arr = [1, 2, 3];

let arr2 = ['今天天气不错', '早上好']
arr2 = arr2.map(s => s.split(''))
// [ [ '今', '天', '天', '气', '不', '错' ], [ '早', '上', '好' ] ]
方法名 参数和说明 返回值 例子
Array.isArray() arr Boolean Array.isArray(arr) // true
Array.prototype.valueOf() 数组本身 arr.valueOf() // [1, 2, 3]
Array.prototype.toString() 数组的字符串形式 arr.toString() // "1,2,3"
Array.prototype.push() elementN,尾部插入值 新的length arr.push(7) // 4
Array.prototype.pop() 删除的元素,删除最后一个元素 arr.pop() // 3
Array.prototype.shift() 删除的元素,删除第一个元素 arr.shift() // 1
Array.prototype.unshift() elementN,首部插入值 新的length arr.shift(7) // 4
Array.prototype.join() separator,默认为'',' 字符串 arr.join('
Array.prototype.concat() array,object,elementN 新数组(浅拷贝) arr.concat([7]) // [1, 2, 3, 7]
Array.prototype.reverse() 颠倒排序之后的原数组 arr.reverse() // [3, 2, 1]
Array.prototype.sort() 无,默认按字典排序,或者传入一个函数 重新排序之后的原数组 arr.sort() // [1, 2, 3]
Array.prototype.map() 回调函数,把每次的执行结果重新组成一个数组 新数组 arr.map(function (n) { return n + 1; }); //[2,3,4]
Array.prototype.forEach() 回调函数,操作原数组 不返回值,改变原数组 arr.forEach(function (n) { console.log(n) }); //1 2 3
Array.prototype.filter() 回调函数,根据筛选项条件得到新数组 新数组 arr.filter(function (item) { return (item > 2) }); //[3]
Array.prototype.some() 回调函数,某一个元素满足条件即返回true,否则返回false Boolean arr.some(function (item) { return item > 2 }); //true
Array.prototype.every() 回调函数,所有元素满足条件即返回true,否则返回false Boolean arr.every(function (item) { return item > 2 }); //false
Array.prototype.reduce() (func, 初始值),从左到右 执行之后的返回值 arr.reduce(function (prev, cur) { return prev+cur }, 10); //16
Array.prototype.reduceRight() (func, 初始值),从右到左 执行之后的返回值 arr.reduceRight(function (prev, cur) { return prev+cur }, 10); //16
Array.prototype.indexOf() (searchElement,fromIndex)第二个参数是开始查找的位置 存在返回索引值,没有返回-1 arr.indexOf(2); //1
Array.prototype.lastIndexOf() (searchElement,fromIndex)第二个参数是开始查找的位置,从右到左 存在返回索引值,没有返回-1 arr.lastIndexOf(3); //2
ES6
Array.from() 类似数组的对象和可遍历的对象 真正的数组 Array.from({'0': 'a','1': 'b','2': 'c', length: 3}); // ["a", "b", "c"]
Array.of() 将一组值转为数组,为了弥补Array()参数不同的行为差异 数组 Array.of(1,2,3); // [1, 2, 3]
Array.prototype.includes() (searchElement,fromIndex),fromIndex可选,便是开始查找的位置 Boolean [1, 2, 3].includes(2); ; // true
Array.prototype.flat() depth,可选参数,默认1,将嵌套数组拉平变成一维数组 新数组 [1, 2, [3, 4, [5, 6]]].flat(2); // [1, 2, 3, 4, 5, 6]
Array.prototype.flatMap() callback, 新数组 arr2.flatMap(s => s.split('')); // ["今", "天", "天", "气", "不", "错", "早", "上", "好"]
Array.prototype.copyWithin() (target, start, end) 将start和end之间的元素复制覆盖target指定的位置,end指定的元素不会复制 数组 [1,2,3,4].copyWithin(1, 2, 3); // [1, 3, 3, 4]
Array.prototype.find() (callback, thisArg) 返回符合条件的第一个值,否则unfettered [1,2,3,4,5].find(function(item){ return item>2 }); // 3
Array.prototype.findIndex() (callback, thisArg) 返回符合条件的第一个值的下标,否则unfettered [1,2,3,4,5].findIndex(function(item){ return item>2 }); // 2
Array.prototype.fill() (value, start, end ),将指定的位置填充为value,如果不指定就全部填充 修改后的数组 [1,2,3,4].fill(7, 2, 3); // [1, 2, 7, 4]
Array.prototype.entries() 可遍历的Iterator对象,[key, value] [1,2,3,4].entries(); // 可被for of遍历
Array.prototype.keys() 可遍历的Iterator对象, key [1,2,3,4].keys(); // 可被for of遍历
Array.prototype.values() 可遍历的Iterator对象, value [1,2,3,4].values(); // 可被for of遍历

字符串处理方法

方法名 参数和说明 返回值 例子
String.fromCharCode() 一个或多个数值,代表Unicode 码点 字符串 String.fromCharCode(104, 101, 108, 108, 111) // 'hello'
String.prototype.charAt() index,下标 字符串 new String('abc').charAt(1) //b
String.prototype.charCodeAt() index,下标 Unicode 码点(十进制表示) 'hello'.charCodeAt(1) // 101
String.prototype.concat() string2...stringN 字符串 'hello'.concat('world', 'haha') // "helloworldhaha"
String.prototype.indexOf() searchValue,fromIndex 第一次出现的索引,没找到就-1 'hello'.indexOf('e') // 1
String.prototype.lastIndexOf() searchValue,fromIndex 第一次出现的索引 'wanwan'.lastIndexOf('a'); //4 'wanwan'.lastIndexOf('a', 3) //1
String.prototype.trim() 无,删除字符串两端空白字符串 新字符串 ' wan '.trim() // 'wan'
String.prototype.toLowerCase() 无,小写 新字符串 'wanCheng'.toLowerCase() // 'wancheng'
String.prototype.toUpperCase() 无,大写 新字符串 'wanCheng'.toUpperCase() // 'WANCHENG'
String.prototype.match() regexp array 'wancheng'.match('wan') // ['wan'] 'wancheng'.match(/\w/) // ['w']
String.prototype.search() regexp 首次匹配成功的索引,不成功为-1 'wancheng'.search('c') //
String.prototype.replace() regexp 新字符串 'wan cheng'.replace(/wan/i, 'san') // "san cheng"
ES6
String.prototype.includes() searchString,position(可选) boolean 'hello world'.includes('hello') // true
String.prototype.startsWith() searchString,position(可选),是否是以给定的字符串开头 boolean 'hello world'.startsWith('h') // true
String.prototype.endsWith() searchString,position(可选),是否是以给定的字符串结尾 boolean 'hello worlds'.endsWith('s') // true
String.prototype.repeat() count([0, +∞]) 新字符串 'wan'.repeat(2) // 'wanwan'
String.prototype.padStart() targetLength,padString (可选) 原字符串 'abc'.padStart(7, 'sd') // "sdsdabc"
String.prototype.padEnd() targetLength,padString (可选) 原字符串 'abc'.padEnd(7, 'sd') // "abcsdsd"

JS常用操作方法图表的更多相关文章

  1. JS常用操作方法

    1.splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目. 注释:该方法会改变原始数组. 1 <script type="text/javascript"& ...

  2. js数组常用操作方法小结(增加,删除,合并,分割等)

    本文实例总结了js数组常用操作方法.分享给大家供大家参考,具体如下: var arr = [1, 2, 3, 4, 5]; //删除并返回数组中第一个元素 var theFirst = arr.shi ...

  3. js常用工具类.

    一些js的工具类 复制代码 /** * Created by sevennight on 15-1-31. * js常用工具类 */ /** * 方法作用:[格式化时间] * 使用方法 * 示例: * ...

  4. chart.js 里添加图表的清单:

    chart.js 里添加图表的清单: var legend = myDoughnut.generateLegend(); $("#chart_legend").html(legen ...

  5. Js常用技巧

    摘录:http://crasywind.blog.163.com/blog/static/7820316920091011643149/ js 常用技巧 1. on contextmenu=" ...

  6. JS常用的标准函数

    原文:JS常用的标准函数 1.Array类型函数 array.concat(item...) 函数功能:关联数组,实现数组相加功能,但并不影响原先数组,concat返回新数组. array.join( ...

  7. JS 常用功能收集

    JS 常用效果收集 1. 回到顶部>>    爱词霸

  8. JS常用校验方法(判断输入框是否为空,数字,电话,邮件,四舍五入等)

    JS常用校验方法: 1.判断输入框是否为空,为空时弹出提示框 2.关闭窗口 3.检查输入字符串是否为数字 4.强制把大写转换成小写 5.手机号码校验,长度为11位数字. 6.电子邮件校验 7.电话号码 ...

  9. Node.js 常用工具

    Node.js 常用工具 util 是一个Node.js 核心模块,提供常用函数的集合,用于弥补核心JavaScript 的功能 过于精简的不足. util.inherits util.inherit ...

随机推荐

  1. linux django 知识点 安装mysql数据库 和 pycharm

     django 命令及相关知识点 1. 启动 pycharm 命令:sh pycharm.sh 2. 创建 django 项目 : django-admin.py startproject Hello ...

  2. C++面向对象高级开发课程(第三周)

    一,类与类之间的关系:继承(Inheritance).复合(Composition).委托(Delegation). 二,复合:表示 is-a ,该设计思想可以参照C语言的 struct . 1. 例 ...

  3. 02: MySQL的安装与基本配置

    MySQL其他篇 目录: 参考网站 1.1 MySQL安装与基本配置(centos 7.3) 1.2 修改MySQL默认字符集和引擎 1.3 MySQL创建用户与授权 1.1 MySQL安装与基本配置 ...

  4. Windows server利用批处理脚本判断端口, 启动tomcat

    win server服务器上面的tomcat老是不定时挂掉, 于是利用定时操作脚本判断tomcat80端口是否在运行, 如果运行则放过, 如果down掉就启动tomcat,解决tomcat不定时挂掉导 ...

  5. 20145303刘俊谦 Exp8 Web基础

    20145303刘俊谦 Exp8 Web基础 基础问题回答 1.什么是表单? 表单是一个包含表单元素的区域,表单元素是允许用户在表单中(比如:文本域.下拉列表.单选框.复选框等等)输入信息的元素,表单 ...

  6. 20145303刘俊谦《网络攻防》Exp4 Msf基础

    20145303刘俊谦<网络攻防>Exp4 Msf基础 实验目标 • 掌握metasploit的基本应用方式,掌握常用的三种攻击方式的思路. • 一个主动攻击,如ms08_067: • 一 ...

  7. Spring Boot + thymeleaf 实现文件上传下载

    参考博客:https://juejin.im/post/5a326dcaf265da431048685e 技术选型:spring boot 2.1.1+thymeleaf+maven 码云地址:htt ...

  8. SqlParameter 参数化模糊查询

    sql += " and a.f_fullName like N'%'+@fullName+'%'";

  9. MVC ---- Lambda表达式

    Lambda表达式是比匿名函数还简洁的一种匿名方法语法 Lambda表达式缩写推演 new Func<string,int>(delegate(string str){return str ...

  10. Python matplot的使用(一)

    其实,使用它的直接原因是因为matlab太大了,不方便.另外,就是它是免费的. 在安装这个库的时候,会需要安装一些它所依赖的库,比如six等.从sourceforge上下载,只需按照提示安装完成就行了 ...