js字符串方法

更新日期: 2019-08-18阅读: 2.8k标签: 字符串
一、查找字符串的位置(找到返回字符串首字母的位置,找不到返回-1):
indexOf("string"):查找字符串string在字符串中首次出现的位置;
indexOf("string",number):从number位置开始往后查找字符串string在字符串中首次出现的位置;number为负数从右侧开始往右查找,直到字符串结束。  
lastIndexOf("string"):查找字符串string在字符串中最后出现的位置;
lastIndexOf("string",number):从number位置开始往后查找字符串string在字符串中最后出现的位置;number为负数从右侧开始往右查找,直到字符串结束。
search("string"):和indexOf一样,区别(不能带参数)。


二、截取字符串:slice、substring、substr比较
方法参数参数为一个参数都为正参数为负 
slice

接收的是起始位置和结束

位置(不包括结束位置)

省略结束位置参数,从参数位置开始截取

到字符串结束,负参数从左开始往右截取

起始位置大于结束位置,

返回空

参数都为负:

从负参数开始截取到负参数结束(起始位置<结束位置)

(起始位置>结束位置)//报错

开始为正,结束为负:

从正参数开始截取到负参数结束

开始为负,结束为正:返回为空

substring参数中有负值,将其转化成0。两个参数中较小的一个作为起始位置。
substr

接收的是起始位置和所要

返回的字符串长度

和slice一样 

返回字符串长度不能为负值(没有意义)。

如果参数为负,相当于截取字符串长度为0.
























三、替换字符串内容
replace("旧的字符串","新字符串")
结合正则表达式替换字符串:
1.对大小写不敏感/i:
var str="good good study";
var res=str.replace(/GOOD/ig,"day");//day good study(默认匹配首个字符串)

2.全局替换:

var str="good good study";
var res=str.replace(/GOOD/g,"day");//day day study


四、转化为大写或小写:

toUpperCase():将都有字符串中的字母都转化成大写;

toLowerCase():将都有字符串中的字母都转化成小写;

var str="good good study";
console.log(str.toUpperCase());//全部转化大写(GOOD GOOD STUDY)
console.log(str.toLowerCase());//全部转化小写(good good study)


五、连接两个字符串或多个concat()

var one="hello",two="world",three="!!!";
var x=one.concat("+","abc",three);
console.log(x)//hello abc !!!
var x=one.concat("+",two,three);
console.log(x)//hello world !!!
//--代替连接符
var x= "hello".concat(" ","world");
var x= "hello".concat(" ","world"," ","world");
console.log(x)//hello world world

六、删除字符串两端的空白trim()

//删除字符串两端的空白符trim()
var str = "       Hello World!        ";
console.log(str.trim());//Hello World;
//去左空格;
/*function ltrim(s){
    return s.replace(/(^\s*)/g,"");//去除左空格
}*/
//去右空格;
/*function rtrim(s){
    return s.replace(/(\s*$)/g,"");//去除右空格
}*/
console.log(ltrim(str));

七、提取字符串字符charAt(i)

var str = "HELLO WORLD";
console.log(str.charAt(0)); //H


八、返回字符串中指定索引的字符 unicode 编码

var str = "HELLO WORLD";
console.log(str.charCodeAt(0));//72 

九、字符串转化成数组split()
var txt = "at,b,cpp,d,e";   // 字符串
var test=txt.split(",");          // 用逗号分隔
var test1=txt.split(" ");          // 用空格分隔
var test2=txt.split("|");          // 用竖线分隔    
console.log(test);//返回数组[0:at,1:b,···]
//如果字符串之间没有符号
var txt = "H,ello";       // 字符串
var txt_= txt.split("");// 分隔为字符
console.log(txt_);     //返回数组[0:H,1:,,···]
var a=txt_.join("");//数组转化成字符串
console.log(txt_);  //H,ello

练习:

//查找字符串中有多少个e
 var str="there is no challess there will be no success";
 var sum=0;
 for(var i=0;i<str.length;i++){
      if(str.charAt(i)=="e"){sum+=1};
      }
 console.log(sum)
 //正则表达式查找有多少个e
 var str="there is no challess there will be no success";
 var res=str.match(/e/g);
 console.log(res.length);
 //查找字符串中任意字符串(查找第二个good)
  var str="good good study";
     function indexof(str1,str2,num){//str1字符串,str2查找的字符串,num查找的第几个(0代表第一个)
         var res=str.indexOf(str2);
         for(var i=0;i<num;i++){
             res=str1.indexOf(str2,res+1);
             }
          return res
         }
  console.log(indexof(str,"good",1));
  //替换第二个good
   var str="good good good study";
   function rep_str(str1,str2,str3,num){//str1字符串,str2需要替换的字符串,str3替换的字符串,num替换的第几个
       var sum=0;
       var strall=str.split(" ");
       for( var i=0; i<str.length;i++){
          if(strall[i]==str2){
              sum+=1;
              if(sum==num){
                strall[i]=str3
              }
          }
       }
       var res=strall.join(" ");
       return res
   }
  console.log(rep_str(str,"good","day",2));

链接: https://fly63.com/article/detial/4784

字符串拼接引发的BUG

我们先温习一下JavaScript基础知识。在JavaScript中,根据+左右两边变量的类型的不同,+符号可以用于数字相加或则字符串拼接。我用了string += +string这样的写法,也就是说:由于写代码的时候拷贝黏贴,不小心整了一个多余的+号?

原生js去掉字符串2端空格Trim()方法总汇

在我们使用JavaScript编写脚本的时候,经常会遇到把字符串两边的空格进行清除,它不想其它语言会有内置方法函数处理,js需要我们自己代码来实现。如果用过jquery库的话,它提供了trim方法,我们可以直接使用。

js中String.prototype实现string过滤空格_字符串空格过滤

我们都知道prototype可以向对象上添加属性和方法,语法如下:object.prototype.name=value。这篇文章就是利用prototype,为字符串扩展过滤空格的方法

字符串的格式化功能的实现_js实现连接字符串及变量

在开发中过程中,经常会遇到使用占位符的形式来格式化字符串,我们通过js扩展String.prototype.format字符串拼接的功能,实现如下:

es6中新增的字符串方法

es6中新增的字符串方法:字符串模板用法${变量名}、字符串查找方法string.includes(要找得字符串)、检查字符串是否已xxx开头、字符串重复方法string.repeat(次数)、字符串填充string.padStart

js中字符串截取的几种方式

众所周知,js提供了很多字符串截取的方式。下面主要介绍js中slice(),splice(),split(),substring(),substr()的使用和区别,主要介绍了JavaScript截取、切割字符串的技巧,需要的朋友可以参考

JavaScript:生成重复的字符串(字符串乘法)

看到一个题目要求写一个函数times,输出str重复num次的字符串。除了利用循环还有几种方法:递归,结合三元表达式更简洁。数组的 join() 方法。ES6的 repeat() 方法。ES6目前没有全部兼容。

常用的String原型

对于常用的字符串原型的举例:在字符串末尾追加字符串 、删除指定索引位置的字符,索引无效将不删除任何字符 、删除指定索引区间的字符串 、检查字符串是否以subStr结尾

使用String. localeCompare比较字符串

javascript提供stringA.localeCompare(stringB)方法,来判断一个字符串stringB是否排在stringA的前面。返回值: 如果引用字符存在于比较字符之前则为负数; 如果引用字符存在于比较字符之后则为正数; 相等的时候返回 0 。

js里面判断一个字符串是否包含某个子串的方法

ES6的includes, 返回 Boolean、ES5 indexOf,返回子串起始位置,不包含则返回-1、search,返回起始位置或者-1、lodash includes, JavaScript 工具库

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!