本文实例总结了javascript中数组(Array)对象和字符串(String)对象的常用方法。分享给大家供大家参考,具体如下:

综述:笔者经常将数组的方法和字符串的方法混淆,这里写篇日志,做个区分
1.字符串对象
String是JavaScript中的五种基本类型之一。
(1)字符串对象的创建
例1:
var str="Hello world";
或者
var str=new String("Hello world")
(2)charAt()方法
charAt()方法用于返回指定位置的字符串,比如我们想返回str字符串中,第二个字符,则可以写成charAt(1),因为字符串的下标也是从0开始,因此我们返回了第二个字符e;
例2:
var str="Hello world"; alert(str.charAt(1)) //输出e
(3)indexOf(注意O要大写)
indexOf()方法,可返回某个指定的字符串值在字符串中首次出现的位置。
例3:
var str="Hello world";alert(str.indexOf('e'))
//输出1
indexOf()方法还可以有第二个参数规定字符串开始检索的位置
(4)split()方法
split()方法,可以按规则分割字符串。比如:
例4:
var x="86-029-19201920";alert(x.split(-)) //输出 86 029 19201920
split()方法还可以有第二个参数,表示分割的次数,如果省略,默认分割次数不限
(5)substring()方法
substring()方法,可以提取字符串,改方法有两个参数,第一个参数表示起始位置,第二个参数表示终止位置,如果省略第二个参数,默认提取到字符串的结尾。
例5:
var x="Hello world";alert(x.substring(0,4)); //输出Hello
(6)substr()方法
substr()方法,也可以用于提取字符串,不同的是该方法的两个参数,第一个参数表示起始位置,第二个参数表示提出字符串的个数。
例6:
var x="Hello world";alert(x.substr(0,5)); //同样输出Hello
2.数组对象(Array)
(1)数组对象的创建
例1:
var arr=new Array(10) ; var arr=[1,2,3]; var arr=new Array(1,2,3); var arr=[];
数组创建的方法一般有这么几种,其中var arr=new Array(1,2,3)这种方式较为少见。
(2)concat()方法
例2:
var x=[1,2,3]; var y=x.concat(4,5); alert(y); //输出y为1,2,3,4,5
concat() 方法用于连接两个或多个数组。此方法返回一个新数组,不改变原来的数组。
(3)join()方法
例3:
var x=[1,2,3]; alert(x.join("-"));
//输出的位1-2-3
join()方法用于把数组中的所有元素放入一个字符串。元素是通过指定的分隔符进行分隔的。
(4)reverse()方法
数组反转,不会生成新的数组
例4:
var x=[1,2,3]; alert(x.reverse()); //输出的位3,2,1
(5)slice()方法
slice() 方法可从已有的数组中返回选定的元素。slice方法也有2个参数,第一个参数表示开始位置,第二个参数表示结束位置。
(6)splice()方法
splice()方法用于在数组中插入或删除元素的通用方法,不同于concat()和slice()方法,splice()会修改调用的数组。
例6:
var a=[1,2,3,4,5,6,7,8]; a.splice(4);//返回[5,6,7,8],a数组变成了[1,2,3,4] a.splice(1,2);//返回[2,3],a数组变成了[1,4] a.splice(1,1);//返回了[4],a数组变成了[1]
注:splice()的第一个参数指定了插入的起始位置,第二个参数指定了应该从数组中插入或删除的元素的个数
splice()返回一个由删除元素组成的数组。
(7)push()和pop()方法
push()和pop()方法允许数组当做栈来使用,push()表示在数组的尾部添加一个或者多个元素,pop()方法则相反。
(8)shift()和unshift()方法
shift()和unshift()方法,非常类似于push()和pop()方法,不同的是前者是在数组的头部而非尾部进行插入和删除操作。
(9)sort()方法
sort()方法使数组中的元素按照一定的顺序排列。
例9:
var x=[1,2,13,113],alert(x.sort()) //默认排序规则为按字母表排序,因为输出 1,113,13,2
如果要使得数组从小到大排序,则为
x.sort(function(a,b){return a-b});
ES5新增的方法
ES5中的数组方法,首先大部分的方法第一个参数接收一个函数,并且对于数组的每个元素调用一次该函数,函数中的参数为第一个参数为数组元素,第二个参数为元素的索引,第三个参数为数组本身
(10)foreach()方法
从头到尾遍历数组,为每个数组调用指定的函数
例10:
var x=[1,2,3,4,5];
alert(x.foreach(function(x,i,a){ a[i]=x*x}))
//返回[1,4,9,16,25]
ES5中还有类似map,filter等方法不一一讨论
3.数组对象和字符串对象方法的互用
我们学过了call和apply函数就能实现字符串方法和数组对象方法的互用
比如:我们想在字符串对象中使用数组对象的方法,可以这样实现:
例:
var x="Hello World"; var y=Array.prototype.slice.call(x);
通过call方法,将x字符串对象转为了y数组对象!!!同理也可以将数组对象转化为字符串对象,
就不在累赘举例了!~
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript数组操作技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
# javascript
# 数组
# Array
# 字符串
# String
# 对象
# 常用方法
# JavaScript之String常见的方法详解
# 用jQuery将JavaScript对象转换为querystring查询字符串的方法
# JavaScript基于扩展String实现替换字符串中index处字符的方法
# JavaScript中的toString()和toLocaleString()方法的区别
# JavaScript中String对象的方法介绍
# JavaScript获取URL中参数querystring的方法详解
# 梳理总结JavaScript的23个String方法
# 第二个
# 第一个
# 组中
# 的是
# 还可以
# 多个
# 遍历
# 变成了
# 或删除
# 是在
# 也有
# 相关内容
# 过了
# 就能
# 首次
# 互用
# 是从
# 感兴趣
# 数据结构
# 给大家
相关文章:
桂林网站制作公司有哪些,桂林马拉松怎么报名?
武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
建站之星后台密码如何安全设置与找回?
制作销售网站教学视频,销售网站有哪些?
,网页ppt怎么弄成自己的ppt?
建设网站制作价格,怎样建立自己的公司网站?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
建站之星后台管理如何实现高效配置?
东莞专业制作网站的公司,东莞大学生网的网址是什么?
如何注册花生壳免费域名并搭建个人网站?
微信小程序 五星评分(包括半颗星评分)实例代码
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
如何使用Golang安装API文档生成工具_快速生成接口文档
常州企业网站制作公司,全国继续教育网怎么登录?
如何选择高性价比服务器搭建个人网站?
建站主机类型有哪些?如何正确选型
官网建站费用明细查询_企业建站套餐价格及收费标准指南
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
学校为何禁止电信移动建设网站?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
如何在阿里云虚拟主机上快速搭建个人网站?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
学校建站服务器如何选型才能满足性能需求?
宝塔建站助手安装配置与建站模板使用全流程解析
如何在阿里云虚拟服务器快速搭建网站?
如何通过山东自助建站平台快速注册域名?
大连网站设计制作招聘信息,大连投诉网站有哪些?
建站之星会员如何解锁更多建站功能?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何在阿里云域名上完成建站全流程?
网站制作员失业,怎样查看自己网站的注册者?
定制建站方案优化指南:企业官网开发与建站费用解析
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
如何打造高效商业网站?建站目的决定转化率
建站与域名管理如何高效结合?
建站之星安装后界面空白如何解决?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
如何在服务器上配置二级域名建站?
平台云上自助建站如何快速打造专业网站?
建站主机选购指南与交易推荐:核心配置解析
如何配置FTP站点权限与安全设置?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
想学网站制作怎么学,建立一个网站要花费多少?
名字制作网站免费,所有小说网站的名字?
如何快速选择适合个人网站的云服务器配置?
一键制作网站软件下载安装,一键自动采集网页文档制作步骤?
*请认真填写需求信息,我们会在24小时内与您取得联系。