js字符串操作总结
字符方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>字符方法</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- charAt方法和charCodeAt方法都接收一个参数,基于0的字符位置
- charAt方法是以单字符字符串的形式返回给定位置的那个字符
- charCodeAt方法获取到的不是字符而是字符编码
- */
- var str="hello world";
- console.log(str.charAt(1));//e
- console.log(str.charCodeAt(1));//101
- //还可以使用方括号加数字索引来访问字符串中特定的字符
- console.log(str[1]);//e
- </script>
- </body>
- </html>
字符串操作方法
concat方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>concat方法</title>
- </head>
- <body>
- <script type="text/javascript">
- var str="hello ";
- var res=str.concat("world");
- console.log(res);//hello world
- console.log(str);//hello 这说明原来字符串的值没有改变
- var res1=str.concat("nihao","!");
- console.log(res1);//hello nihao! 说明concat方法可以接收任意多个参数
- //虽然concat方法是专门用来拼接字符串的,但是实践中我们使用最多的还是加操作符+,因为其简易便行
- </script>
- </body>
- </html>
slice方法、substring方法、substr方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>字符串操作方法</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- slice方法:第一个参数指定子字符串开始位置,第二个参数表示子字符串最后一个字符后面的位置
- substring方法:第一个参数指定子字符串开始位置,第二个参数表示子字符串最后一个字符后面的位置
- substr方法:第一个参数指定子字符串开始位置,第二个参数表示返回的字符个数
- 这三个方法都会返回被操作字符串的一个子字符串,都接收一或两个参数
- 如果没有给这些方法传递第二个参数,则将字符串的长度作为结束位置。这些方法也不会修改字符串本身,只是返回一个基本类型的字符串值
- */
- var str="hello world";
- console.log(str.slice(3));//lo world
- console.log(str.substring(3));//lo world
- console.log(str.substr(3));//lo world
- console.log(str.slice(3,7));//lo w 7表示子字符串最后一个字符后面的位置 简单理解就是包含头不包含尾
- console.log(str.substring(3,7));//lo w
- console.log(str.substr(3,7));//lo worl 7表示返回7个字符
- console.log(str.slice(3,-4));//lo w -4+11=7表示子字符串最后一个字符后面的位置 简单理解就是包含头不包含尾
- console.log(str.substring(3,-4));//hel 会转换为console.log(str.substring(3,0));
- //此外由于这个方法会将较小数作为开始位置,较大数作为结束位置,所以相当于调用console.log(str.substring(0,3));
- console.log(str.substr(3,-4));//""空字符串
- console.log(str.substring(3,0));
- </script>
- </body>
- </html>
字符串位置方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>字符串位置方法</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- indexOf方法和lastIndexOf方法都是从一个字符串中搜索给定的子字符串,然后返回子字符串的位置,如果没有找到,则返回-1
- indexOf方法是从字符串的开头向后搜索子字符串,lastIndexOf方法正好相反
- 这两个方法都可以接收两个参数:要查找的子字符串和查找的位置
- */
- var str="hello world";
- console.log(str.indexOf("o"));//4
- console.log(str.lastIndexOf("o"));//7
- console.log(str.indexOf("o",6));//7
- console.log(str.lastIndexOf("o",6));//4
- </script>
- </body>
- </html>
trim方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>trim方法</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- trim方法用来删除字符串前后的空格
- */
- var str=" hello world ";
- console.log('('+str.trim()+')');//(hello world)
- console.log('('+str+')');//( hello world )
- </script>
- </body>
- </html>
字符串大小写转换方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>大小写转换</title>
- </head>
- <body>
- <script type="text/javascript">
- var str="HELLO world";
- console.log(str.toLowerCase());//hello world
- console.log(str.toUpperCase());//HELLO WORLD
- </script>
- </body>
- </html>
字符串模式匹配方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>字符串模式匹配</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- match方法:只接受一个参数,由字符串或RegExp对象指定的一个正则表达式
- search方法:只接受一个参数,由字符串或RegExp对象指定的一个正则表达式
- search方法返回字符串中第一个匹配项的索引,如果没有匹配项,返回-1
- */
- var str="cat,bat,sat,fat";
- var pattern=/.at/;
- var matches=str.match(pattern);
- console.log(matches.index);//0
- console.log(matches[0]);//cat
- console.log(pattern.lastIndex);//0
- //lastIndex表示开始搜索下一个匹配项的字符位置,从0算起
- var pos=str.search(/at/);
- console.log(pos);//1 1表示at字符串在原来字符串中第一次出现的位置
- </script>
- </body>
- </html>
replace方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>replace方法</title>
- </head>
- <body>
- <script type="text/javascript">
- var str="cat,bat,sat,fat";
- var res=str.replace("at","one");//第一个参数是字符串,所以只会替换第一个子字符串
- console.log(res);//cone,bat,sat,fat
- var res1=str.replace(/at/g,"one");//第一个参数是正则表达式,所以会替换所有的子字符串
- console.log(res1);//cone,bone,sone,fone
- </script>
- </body>
- </html>
split方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>split方法</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- split方法是基于指定的字符,将字符串分割成字符串数组
- 当指定的字符为空字符串时,将会分隔整个字符串
- */
- var str="red,blue,green,yellow";
- console.log(str.split(","));//["red", "blue", "green", "yellow"]
- console.log(str.split(",",2));//["red", "blue"] 第二个参数用来限制数组大小
- console.log(str.split(/[^\,]+/));// ["", ",", ",", ",", ""]
- //第一项和最后一项为空字符串是因为正则表达式指定的分隔符出现在了子字符串的开头,即"red"和"yellow"
- //[^...] 不在方括号内的任意字符 只要不是逗号都是分隔符
- </script>
- </body>
- </html>
localeCompare方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>localeCompare方法</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- 这个方法用于比较两个字符串
- 1.如果字符串在字母表中应该排在字符串参数之前,则返回一个负数
- 1.如果字符串等于字符串参数,则返回0
- 1.如果字符串在字母表中应该排在字符串参数之后,则返回一个正数
- */
- var str="yellow";
- console.log(str.localeCompare("brick"));//1
- console.log(str.localeCompare("yellow"));//0
- console.log(str.localeCompare("zoo"));//-1
- </script>
- </body>
- </html>
fromCharCode方法
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>fromCharCode方法</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- fromCharCode方法是接收一或多个字符编码,然后将其转换为字符串
- fromCharCode方法是String构造函数的一个静态方法
- */
- console.log(String.fromCharCode(104,101,108,108,111));//hello
- </script>
- </body>
- </html>
找到匹配字符串所在的各个位置
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>字符串匹配</title>
- </head>
- <body>
- <script type="text/javascript">
- /*找到匹配字符串所在的各个位置*/
- var str="asadajhjkadaaasdasdasdasd";
- var position=[];
- var pos=str.indexOf("d");
- while(pos>-1){
- position.push(pos);
- pos=str.indexOf("d",pos+1);
- }
- console.log(position);//[3, 10, 15, 18, 21, 24]
- </script>
- </body>
- </html>
字符串去重
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>字符串去重</title>
- </head>
- <body>
- <script type="text/javascript">
- //String.split() 执行的操作与 Array.join 执行的操作是相反的
- //split() 方法用于把一个字符串分割成字符串数组。
- //join方法用于将字符串数组连接成一个字符串
- //如果把空字符串 ("") 用作 separator,那么 stringObject 中的每个字符之间都会被分割。
- var str="aahhgggsssjjj";//这里字符串没有可以分隔的字符,所以需要使用空字符串作为分隔符
- function unique(msg){
- var res=[];
- var arr=msg.split("");
- //console.log(arr);
- for(var i=0;i<arr.length;i++){
- if(res.indexOf(arr[i])==-1){
- res.push(arr[i]);
- }
- }
- return res.join("");
- }
- console.log(unique(str));//ahgsj
- </script>
- </body>
- </html>
判断字符串中字符出现的次数
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>字符串操作</title>
- </head>
- <body>
- <script type="text/javascript">
- /*
- 1.先实现字符串去重
- 2.然后对去重后的数组用for循环操作,分别与原始数组中各个值进行比较,如果相等则count++,循环结束将count保存在sum数组中,然后将count重置为0
- 3.这样一来去重后的数组中的元素在原数组中出现的次数与sum数组中的元素是一一对应的
- */
- var str="aacccbbeeeddd";
- var sum=[];
- var res=[];
- var count=0;
- var arr=str.split("");
- for(var i=0;i<arr.length;i++){
- if(res.indexOf(arr[i])==-1){
- res.push(arr[i]);
- }
- }
- for(var i=0;i<res.length;i++){
- for(var j=0;j<arr.length;j++){
- if(arr[j]==res[i]){
- count++;
- }
- }
- sum.push(count);
- count=0;
- }
- console.log(res);//["a", "c", "b", "e", "d"]
- for(var i=0;i<res.length;i++){
- var str=(sum[i]%2==0)?"偶数":"奇数";
- console.log(res[i]+"出现了"+sum[i]+"次");
- console.log(res[i]+"出现了"+str+"次");
- }
- </script>
- </body>
- </html>
阿里面试-字符串操作
- <script type="text/javascript">
- var str = "www.taobao.com";
- var res = str.split("").reverse().join("").replace('oat','');
- console.log(res);//moc.oab.www
- </script>
js字符串操作总结的更多相关文章
- js字符串操作
javascript中字符串常用操作总结.JS字符串操作大全 String对象属性 (1) length属性 length算是字符串中非常常用的一个属性了,它的功能是获取字符串的长度.当然需要注意的是 ...
- 页面循环绑定(变量污染问题),js面向对象编程(对象属性增删改查),js字符串操作,js数组操作
页面循环绑定(变量污染问题) var lis = document.querySelectorAll(".ul li") for ( var i = 0 ; i < lis. ...
- js 字符串操作函数有哪些
js 字符串操作函数有哪些 一.总结 一句话总结:js字符串函数都是字符串对象的方法,是通过调用字符串方法的方式调用,和java,php里面不一样. 1.字符串替换函数怎么用? 这里的正则表示是加双引 ...
- js字符串操作函数
js字符串函数 JS自带函数 concat 将两个或多个字符的文本组合起来,返回一个新的字符串. var a = "hello"; var b = ",world&quo ...
- js字符串操作总结(必看篇)
本文链接: https://www.jb51.net/article/97915.htm 字符方法 <!DOCTYPE html> <html lang="en" ...
- javascript中字符串常用操作总结、JS字符串操作大全
字符串的操作在js中非常频繁,也非常重要.以往看完书之后都能记得非常清楚,但稍微隔一段时间不用,便会忘得差不多,记性不好是硬伤啊...今天就对字符串的一些常用操作做个整理,一者加深印象,二者方便今后温 ...
- JS字符串操作大全
String对象属性 (1) length属性 length算是字符串中非常常用的一个属性了,它的功能是获取字符串的长度.当然需要注意的是js中的中文每个汉字也只代表一个字符,这里可能跟其他语言有些不 ...
- js--javascript中字符串常用操作总结、JS字符串操作大全
字符串的操作在js中非常频繁,也非常重要.以往看完书之后都能记得非常清楚,但稍微隔一段时间不用,便会忘得差不多,记性不好是硬伤啊...今天就对字符串的一些常用操作做个整理,一者加深印象,二者方便今后温 ...
- js 字符串操作函数
concat() – 将两个或多个字符的文本组合起来,返回一个新的字符串. indexOf() – 返回字符串中一个子串第一处出现的索引.如果没有匹配项,返回 -1 . charAt() – 返回指定 ...
随机推荐
- redis客户端可以连接集群,但JedisCluster连接redis集群一直报Could not get a resource from the pool
一,问题描述: (如题目)通过jedis连接redis单机成功,使用JedisCluster连接redis集群一直报Could not get a resource from the pool 但是使 ...
- 设计模式 --> (16)观察者模式
观察者模式 定义对象间的 一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新.它还有两个别名,依赖(Dependents),发布- 订阅(Publish-Sub ...
- 深入理解Java对象的创建过程:类的初始化与实例化
摘要: 在Java中,一个对象在可以被使用之前必须要被正确地初始化,这一点是Java规范规定的.在实例化一个对象时,JVM首先会检查相关类型是否已经加载并初始化,如果没有,则JVM立即进行加载并调用类 ...
- [15单片机] STC15F104W开发入门及模拟串口程序
STC15F104W开发入门及模拟串口程序 Saturday, 31. March 2018 09:42AM - beautifulzzzz 前言 最近找到一款51内核的SOP8封装的8脚单片机STC ...
- 201621123043 《Java程序设计》第7周学习总结
1. 本周学习总结 2.书面作业 1. GUI中的事件处理 1.1 写出事件处理模型中最重要的几个关键词. 事件:用户的操作. 事件源:产生事件的组件. 事件监听程序:对事件进行处理的操作所引发的相关 ...
- C++类型萃取
stl中的迭代器和C++中的类型萃取: http://www.itnose.net/detail/6487058.html 赐教!
- Tornado 协程
同步异步I/O客户端 from tornado.httpclient import HTTPClient,AsyncHTTPClient def ssync_visit(): http_client ...
- 亚马逊AWS学习——EC2的自定义VPC配置
1 网络配置 EC2即亚马逊AWS云服务中的虚拟主机.创建EC2实例时如果使用的默认VPC并分配了公有IP是可以上网的.但我们经常需要自定义的网络环境,这时就需要自己定义VPC和子网了. 1.1 配置 ...
- EVA 4400存储硬盘故障数据恢复方案和数据恢复过程
EVA系列存储是一款以虚拟化存储为实现目的的HP中高端存储设备,平时数据会不断的迁移,加上任务通常较为繁重,所以磁盘的负载相对是较重的,也是很容易出现故障的.EVA是依靠大量磁盘的冗余空间,以及故障后 ...
- 记一次SQL调优/优化(SQL tuning)——性能大幅提升千倍以上
好久不写东西了,一直忙于各种杂事儿,恰巧昨天有个用户研发问到我一个SQL调优的问题,说性能太差,希望我能给调优下,最近有些懒,可能和最近太忙有关系,本来打算问问现在的情况,如果差不多就不调了,那哥们儿 ...