热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Js中的字符串/数组中常用的操作

JS为每种数据类型都内置很多方法,真的不好记忆,而且有些还容易记混,现整理如下,以便以后查看:一、String

JS为每种数据类型都内置很多方法,真的不好记忆,而且有些还容易记混,现整理如下,以便以后查看:

一、String

①charAt()方法用于返回指定索引处的字符。返回的字符是长度为 1 的字符串。

语法:stringObject.charAt(index)  

index 必需,表示字符串中某个位置的数字。字符串中第一个字符的下标是 0。如果参数 index 不在 0 与 string.length-1 之间,该方法将返回一个空字符串。

1 var str="fighting 2018!";
2 str.charAt(3);//h

②indexOf()方法可返回某个指定的字符串值在字符串中首次出现的位置。

语法:stringObject.indexOf(str,startpos)

str 必需,给定的需要检索的字符串。 startpos 可选的整数参数,规定在字符串中开始检索的位置。它的合法取值是 0 到 stringObject.length - 1。如省略该参数,则将从字符串的首字符开始检索。

var str="fighting 2018!";
str.indexOf("t");//4

③split()方法将字符串分割成字符串数组,并返回此数组

语法:stringObject.split(separator,limit)

separator 必需,从该参数指定的地方分割。 limit 可选,分割的次数

"2:3:4:5".split(":") //将返回["2", "3", "4", "5"]
"|a|b|c".split("|") //将返回["", "a", "b", "c"]

④substring()方法用于提取字符串中介于两个指定下标之间的字符,其内容是从 start 处到 stop-1 处的所有字符,其长度为 stop 减 start。

语法:stringObject.substring(start,stop)

start 必需,一个非负的整数,规定要提取的子串的第一个字符在 stringObject 中的位置。

stop 可选,一个非负的整数,比要提取的子串的最后一个字符在 stringObject 中的位置多 1。如果省略该参数,那么返回的子串会一直到字符串的结尾。

1 var str="Hello world!";
2 document.write(str.substring(3));//lo world!
3 document.write(str.substring(3,8));//lo wo

⑤substr()方法在字符串中抽取从 start 下标开始的指定数目的字符。

语法:stringObject.substr(start,length)

start 必需,要抽取的子串的起始下标。必须是数值。如果是负数,那么该参数声明从字符串的尾部开始算起的位置。也就是说,-1 指字符串中最后一个字符,-2 指倒数第二个字符,以此类推。

length 可选,必须是数值。如果省略了该参数,那么返回从 stringObject 的开始位置到结尾的字串。

1 var str="Hello world!";
2 document.write(str.substr(3));//lo world!
3 document.write(str.substr(3,7));//lo worl

⑥replace()方法用于在字符串中用一些字符替换掉另一些字符,或替换掉一个与正则表达式匹配的子串。

语法:stringObject.replace(regexp/substr,newsubstr/function)

regexp/substr 必需,规定要替换掉的子字符串或要替换掉的模式的 RegExp 对象。

newsubstr/function 必需,规定了替换文本或生成替换文本的函数。

1 var str="Visit Microsoft!";
2 document.write(str.replace(/Microsoft/, "W3School"));//Visit W3School!
3 var name = "Doe, John";
4 document.write(name.replace(/(\w+)\s*, \s*(\w+)/, "$2 $1"));//John Doe

⑦charCodeAt()方法可返回指定位置的字符的 Unicode 编码。这个返回值是 0 - 65535 之间的整数。

语法:stringObject.charCodeAt(index)

index 必需,表示字符串中某个位置的数字,即字符在字符串中的下标。

1 var str="Hello world!";
2 document.write(str.charCodeAt(1));//101

⑧formCharCode()方法接受一个指定的 Unicode 值,然后返回一个字符串。

语法:String.fromCharCode(numX,numX,...,numX)

numX 必需,一个或多个 Unicode 值,即要创建的字符串中的字符的 Unicode 编码。

1 document.write(String.fromCharCode(72,69,76,76,79));//HELLO
2 document.write(String.fromCharCode(65,66,67));//ABC

二、Math

①ceil()方法 对一个数进行向上取整

语法:Math.ceil(x)  返回大于等于x 并且与x最接近的整数

②floor()方法 对一个数进行向下取整

语法:Math.floor(x) 返回小于等于x 并且与x最接近的整数

③round()方法 对一个数进行四舍五入取整

语法:Math.round(x) 返回最接近x的整数

④random()方法 返回介于 0 ~ 1 之间的一个随机数

语法:Math.random() 返回0.0 ~ 1.0 之间的一个随机数。

⑤max()方法返回指定的数中带有较大的值的那个数

语法:Math.max(x1,x2,.....) 返回x1,x2,.....中带有最高值的数字  如果有某个参数为 NaN,或是不能转换成数字的非数字值,则返回 NaN。

⑥min()方法返回指定的数中带有较小的值的那个数

语法:Math.min(x1,x2,......) 返回x1,x2,.....中带有最小值的数字  如果有某个参数为 NaN,或是不能转换成数字的非数字值,则返回 NaN。

1 Math.ceil(3.2);//4
2 Math.floor(3.7);//3
3 Math.round(3.5);//4
4 Math.random();//一个随机数
5 Math.max(3,6,6.2);//6.2
6 Math.min(3,4,34);//3

三、Array

①concat()方法用于连接两个或多个数组。返回一个新的数组

语法:arrayObject.concat(arrayX,arrayX,......,arrayX)

arrayX 必需,该参数可以是具体的值,也可以是数组对象。可以是任意多个。

注:该方法不会改变原有的数组arrayObject,而仅仅会返回一个新,该数组是通过把所有 arrayX 参数添加到 arrayObject 中生成的。如果要进行 concat() 操作的参数是数组,那么添加的是数组中的元素,而不是数组。

1 var a = [1,2,3];
2 var b=[4,5,6];
3 var c=a.concat(7,b);
4 document.write(c);//1,2,3,7,4,5,6

②join()方法用于把数组中的所有元素放入一个字符串。返回一个字符串,不改变原数组。

语法:arrayObject.join(separator)

separator 可选,指定要使用的分隔符。如果省略该参数,则使用逗号作为分隔符。

1 var arr=["I","like","Front-end"];
2 var str=arr.join(" ");
3 document.write(str);//I like Front-end

③reverse()方法用于颠倒数组中元素的顺序,该方法会改变原来的数组,而不会创建新的数组。

语法:arrayObject.reverse()

var arr = new Array(3);
arr[0] = "a";
arr[1] = "b";
arr[2] = "c";
document.write(arr + "
");//a,b,c
document.write(arr.reverse());//c,b,a

④slice()方法从已有的数组中返回选定的元素构成一个新的数组。不改变原数组

语法:arrayObject.slice(start,end)   返回的新数组包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。

start 必需,规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。

end 可选,。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。

1 var arr=[1,2,3,4,5,6];
2 var newArr=arr.slice(1,3);
3 document.write(newArr);//2,3
4 document.write(arr);//1,2,3,4,5,6

⑤sort()方法使数组中的元素按照一定的顺序进行重新排序,该方法会改变原来的数组。

语法:arrayObject.sort(sortby)

sortby 可选,若使用时未传入参数,默认排序规则,是按照字符编码的顺序进行排序;若使用该参数,必须是函数(比较函数)规定排序顺序,即接收一个比较函数来实现自定义的排序。

比较函数要比较两个值,应该具有两个参数 a 和 b,然后返回一个用于说明这两个值的相对顺序的数字。

var sortby=function(a,b){

//函数体     注:开始时 a=arrayObject[0],b=arrayObject[1];然后a=调整后的arrayObject[1],b=调整后的arrayObject[2];以此类推,直到数组合中的元素全部循环判断一

}

其返回值如下:

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值,此时不调换a、b顺序。
  • 若 a 等于 b,则返回 0,此时不调换a、b顺序。
  • 若 a 大于 b,则返回一个大于 0 的值,此时调换a、b的顺序。

1 var arr = [10, 20, 1, 2];
2 //将数组中的元素按从小到大排列
3 arr.sort(function(a,b){
4 return a-b;
5 });
6 document.write(arr);//1,2,10,20

⑥splice()方法 向/从数组中添加/删除项目,然后返回被删除的项目组成的数组。该方法会改变原始数组。

语法:arrayObject.splice(index,howmany,item1,.....,itemX)

删除从index处开始的howmany个元素,并且可用列表中声明的一个或者多个值(item1,.....,itemX)来替换那些被删除的元素。

index 必需,整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。howmany 必需,要删除的项目数量。如果设置为 0,则不会删除项目。 item1,.....,itemX可选,向数组添加的新项目。

1 var arr=[1,2,3,4,5,6,7];
2 document.write(arr.splice(1,2,8,9));//2,3
3 document.write(arr);//1,8,9,4,5,6,7

⑦map()方法按照原始数组元素顺序依次处理元素。map()方法可以方便的遍历数组。返回一个新数组,不会改变原始数组。

语法:arrayObject.map(function(currentValue,index,arr), thisValue)

function(currentValue, index,arr) 必需,函数,数组中的每个元素都会执行这个函数。map()方法可给该回调函数传入三个值:currentValue (必选 当前元素的值); index (可选 当前元素的索引);

                                                                                                                                                                    arr (可选 当前元素属于的数组对象。后两者在回调函数中根据是否需要来决定是否作为参数传入)。

thisValue 可选,网上查到的说法是:对象作为该执行回调时使用,传递给函数,用作 "this" 的值。如果省略了 thisValue ,"this" 的值为 "undefined"。一般用不到该参数。

1 var oldArray=[1,2,3];
2 var newArray=oldArray.map(function(val){
3 return val+=3;
4 });
5 alert(newArray);//4,5,6

⑧reduce()方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。reduce()方法可以方便的迭代数组。不会改变原数组。

语法:arrayObject.reduce(function(previousValue, currentValue, currentIndex, arr), initialValue)

function(previousValue, currentValue, currentIndex, arr) 必需,函数,reduce()方法可给该回调函数传入四个值:previousValue (必选 上一次调用回调返回的值,或者是提供的初始值(initialValue));currentValue (必选 数组中当前被处理的元素);

currentIndex(可选 当前元素在数组中的索引);arr (可选 调用 reduce 的数组) 。  

initialValue 可选,若不设置。则初始值将变成数组中的第一项,而currentValue即从数组中的第二项开始。

1 var arr=[2,4,3,7];
2 //数组中的元素进行累加
3 var val=arr.reduce(function(n1,n2){
4 return n1+n2;
5 },0);
6 document.write(val);//16

⑨filter()方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。filter()方法可以方便的遍历数组,对元素进行过滤。不会改变原始数组。

 语法:arrayObject.filter(function(currentValue,index,arr), thisValue)

function(currentValue,index,arr) 必选,函数,filter()方法可给该回调函数传入三个值:currentValue(必选 当前元素的值);index(可选 当前元素在数组中的索引);arr(可选 调用filter的数组)。

thisValue 可选,网上查到的说法是:对象作为该执行回调时使用,传递给函数,用作 "this" 的值。如果省略了 thisValue ,"this" 的值为 "undefined"。一般用不到该参数。

1 var oldArr=[1,2,3,55,65,34];
2 var newArr=oldArr.filter(function(val){
3 return val>30;
4 });
5 document.write(newArr);//55,65,34

 ⑩arrayObject.pop()  移除arrayObject中的最后一个元素,并返回该元素,改变原数组;

    arrayObject.push(item1,item2,....) 将一个或多个参数item添加到数组arrayObject的尾部,改变原数组,并返回改变后的数组的长度;

    arrayObject.shift() 移除arrayObject中的第一个元素,并返回该元素,改变原数组;

    arrayObject.unshift(item1,item2,....)将一个或多个参数item添加到数组arrayObject的头部,改变原数组,并返回改变后的数组的长度;

转:https://www.cnblogs.com/xumBlog/p/8505906.html



推荐阅读
  • 本文介绍了UUID(通用唯一标识符)的概念及其在JavaScript中生成Java兼容UUID的代码实现与优化技巧。UUID是一个128位的唯一标识符,广泛应用于分布式系统中以确保唯一性。文章详细探讨了如何利用JavaScript生成符合Java标准的UUID,并提供了多种优化方法,以提高生成效率和兼容性。 ... [详细]
  • 题目描述:牛客网新员工Fish每天早上都会拿着一本英文杂志,在本子上写下一些句子。他的同事Cat对这些句子非常感兴趣,但发现这些句子的单词顺序被反转了。例如,“student. a am I”实际上是“I am a student.”。Cat请求你帮助他恢复这些句子的正常顺序。 ... [详细]
  • 2022年7月20日:关键数据与市场动态分析
    2022年7月20日,本文对当日的关键数据和市场动态进行了深入分析。主要内容包括:1. 关键数据的解读与趋势分析;2. 市场动态的变化及其对投资策略的影响;3. 相关经济指标的评估。通过这些分析,帮助读者更好地理解当前市场环境,为决策提供参考。 ... [详细]
  • 检查在所有可能的“?”替换中,给定的二进制字符串中是否出现子字符串“10”带 1 或 0 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 本指南从零开始介绍Scala编程语言的基础知识,重点讲解了Scala解释器REPL(读取-求值-打印-循环)的使用方法。REPL是Scala开发中的重要工具,能够帮助初学者快速理解和实践Scala的基本语法和特性。通过详细的示例和练习,读者将能够熟练掌握Scala的基础概念和编程技巧。 ... [详细]
  • 本文总结了JavaScript的核心知识点和实用技巧,涵盖了变量声明、DOM操作、事件处理等重要方面。例如,通过`event.srcElement`获取触发事件的元素,并使用`alert`显示其HTML结构;利用`innerText`和`innerHTML`属性分别设置和获取文本内容及HTML内容。此外,还介绍了如何在表单中动态生成和操作``元素,以便更好地处理用户输入。这些技巧对于提升前端开发效率和代码质量具有重要意义。 ... [详细]
  • 本文介绍了如何在iOS平台上使用GLSL着色器将YV12格式的视频帧数据转换为RGB格式,并展示了转换后的图像效果。通过详细的技术实现步骤和代码示例,读者可以轻松掌握这一过程,适用于需要进行视频处理的应用开发。 ... [详细]
  • HBase Java API 进阶:过滤器详解与应用实例
    本文详细探讨了HBase 1.2.6版本中Java API的高级应用,重点介绍了过滤器的使用方法和实际案例。首先,文章对几种常见的HBase过滤器进行了概述,包括列前缀过滤器(ColumnPrefixFilter)和时间戳过滤器(TimestampsFilter)。此外,还详细讲解了分页过滤器(PageFilter)的实现原理及其在大数据查询中的应用场景。通过具体的代码示例,读者可以更好地理解和掌握这些过滤器的使用技巧,从而提高数据处理的效率和灵活性。 ... [详细]
  • 本文详细解析了一种实用的函数,用于从URL中提取查询参数。该函数通过处理URL中的搜索部分,能够高效地获取并解析出所需的参数值,适用于各种Web开发场景。 ... [详细]
  • 本文全面解析了 Python 中字符串处理的常用操作与技巧。首先介绍了如何通过 `s.strip()`, `s.lstrip()` 和 `s.rstrip()` 方法去除字符串中的空格和特殊符号。接着,详细讲解了字符串复制的方法,包括使用 `sStr1 = sStr2` 进行简单的赋值复制。此外,还探讨了字符串连接、分割、替换等高级操作,并提供了丰富的示例代码,帮助读者深入理解和掌握这些实用技巧。 ... [详细]
  • 在ElasticStack日志监控系统中,Logstash编码插件自5.0版本起进行了重大改进。插件被独立拆分为gem包,每个插件可以单独进行更新和维护,无需依赖Logstash的整体升级。这不仅提高了系统的灵活性和可维护性,还简化了插件的管理和部署过程。本文将详细介绍这些编码插件的功能、配置方法,并通过实际生产环境中的应用案例,展示其在日志处理和监控中的高效性和可靠性。 ... [详细]
  • 在PHP中,高效地分割字符串是一项常见的需求。本文探讨了多种技术,用于在特定字符(如“或”)后进行字符串分割。通过使用正则表达式和内置函数,可以实现更加灵活和高效的字符串处理。例如,可以使用 `preg_split` 函数来实现这一目标,该函数允许指定复杂的分隔符模式,从而提高代码的可读性和性能。此外,文章还介绍了如何优化分割操作以减少内存消耗和提高执行速度。 ... [详细]
  • 通过使用 `pandas` 库中的 `scatter_matrix` 函数,可以有效地绘制出多个特征之间的两两关系。该函数不仅能够生成散点图矩阵,还能通过参数如 `frame`、`alpha`、`c`、`figsize` 和 `ax` 等进行自定义设置,以满足不同的可视化需求。此外,`diagonal` 参数允许用户选择对角线上的图表类型,例如直方图或密度图,从而提供更多的数据洞察。 ... [详细]
  • 本文详细介绍了Oracle数据库中的表空间及其分区技术。表空间作为Oracle数据库的一个逻辑单元,每个数据库可包含一个或多个表空间,每个表空间则关联一个或多个数据文件。通过合理的表空间管理和分区策略,可以显著提升数据库的性能和管理效率。文章还总结了实际应用中的最佳实践,为读者提供了宝贵的参考。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有