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() – 返回指定 ...
随机推荐
- Markdown 语法手册 (完整整理版)
http://blog.csdn.net/witnessai1/article/details/52551362
- 深入学习Redis(1):Redis内存模型
前言 Redis是目前最火爆的内存数据库之一,通过在内存中读写数据,大大提高了读写速度,可以说Redis是实现网站高并发不可或缺的一部分. 我们使用Redis时,会接触Redis的5种对象类型(字符串 ...
- Hibernate 介绍及其 环境搭建
介绍 数据持久化概念 数据持久化是将内存中的数据模型转换为存储模型,以及将存储模型转换为内存中的数据模型的统称.例如:文件的存储.数据的读取等都是数据持久化操作.数据模型可以是任何数据结构或对象模型, ...
- 【itchat】用Python玩耍微信
[itchat] itchat是个基于网页版微信的python微信API.功能目前做到基本可以满足正常的消息收发,信息的获取等等.不过对于红包之类网页版微信不支持的功能,这个模块自然也就无法支持了. ...
- 【Python】 闭包&装饰器
python中的函数本身就是对象,所以可以作为参数拿来传递.同时其允许函数的层级嵌套定义,使得灵活性大大增加. 闭包 闭包的定义:将函数的语句块与其运行所需要的环境打包到一起,得到的就是闭包对象.比如 ...
- 网络通信 --> 同步、异步、阻塞与非阻塞介绍
同步.异步.阻塞与非阻塞介绍 聊聊同步.异步.阻塞与非阻塞
- jQuery学习笔记 .addClass()/.removeClass()简单学习
使用jQuery或javaScript来动态改变页面中某个或部分元素的样式,为了实现这样的功能,我们往往都是使用jQuery或javaScript来控制HTML中DOM的类名(class)从而实现增加 ...
- css代码整理
width:(宽度) height:(高度) border:1px solid red:(边框 :边框粗细 显示 颜色) border-radius:10deg:(边框变圆角) box-shadow: ...
- C语言结构体作业
一.PTA实验作业 题目1:6-3 结构体数组中查找指定编号人员 1. 本题PTA提交列表 2. 设计思路 定义一个结构体指针*p for i=0 to i=7 如果std+i的编号与输入的编号一样 ...
- 学号:201621123032 《Java程序设计》第8周学习总结
1:本周学习总结 2:书面作业 2.1:ArrayList代码分析 2.1.1:解释ArrayList的contains源代码 Contains方法调用indexof方法,如果元素为null,则循环比 ...