zoukankan      html  css  js  c++  java
  • 面向对象认识JS-内置对象(重点)--string

    string

    string对象构造函数 ——字符串即对象

    传统方式 :var zhangsan ='张三';

    通过对象形式:var lisi = new String('李四');

    字符串对象属性和方法概述

    获取字符串长度Length属性
    连接字符串:concat
    获取索引值:indexOf()
    根据索引值获取单个字符:charAt()

    concat方法

        var s1="a";
        var s2="b";
        var s3="c";
        console.log(s1.concat(s2,s3));//abc
    
        var arr = [1, 2, 3];
        console.log(arr.concat(4, 5));//[1,2,3,4,5]
    

    indexOf --- 找到匹配项返回索引值,如果没找到返回-1

        var myString="JavaScript";
        var a1=myString.indexOf("v");//2
        var a2=myString.indexOf("S");//4
        var a3=myString.indexOf("Script");//4
        var a4=myString.indexOf("key");// 如果没有匹配项返回 -1
    

      完整的indexof用法

    可以传入第二个参数:indexOf(str,fromIndex)
    表示从索引位置fromIndex开始查找,如果fromIndex省略,则表示默认从起始索引0开始查找;
    若fromIndex为负,则从索引0开始查找。

        var b1 = myString.indexOf("v",5);// 从下标5开始查找,而v在索引2,所以找不到,返回-1
        var b2 = myString.indexOf("v",1);//-2
        console.log(b1)//-1
        console.log(b2)//-2
    

    charAt  ---- 返回指定索引位置的字符,若索引越界,返回空字符串。

    返回指定索引位置的字符
    (因为Javascript中没有字符类型,所以返回的是长度为1的字符串)。

        myString="JavaScript";
        console.log(myString.charAt(1));//a
        console.log(myString.charAt(10000000000000000));//若索引越界,返回空字符串
        console.log(myString.charAt(-1));//若索引越界,返回空字符串  -- ""
        console.log(myString.charAt(-10000000000000000000000));//若索引越界,返回空字符串
    

    substr(fromIndex,length) 获取部分字符串,从起始索引fromIndex开始截取长度length的字符串

    myString="JavaScript";

    从起始索引fromIndex开始截取长度length的字符串 - 正向截取

        console.log(myString.substr(1,1));//a          表示从第1个索引值开始截取,截取1个字符
        console.log(myString.substr(1,2));//av女忧     表示从第1个索引值开始截取,截取2个字符
    

    若不指定length或者length超过可截取的最大长度,则截取到结尾。 

        console.log(myString.substr(1));//avaScript
        console.log(myString.substr(1,4000000));//avaScript
    

    反向截取
    若起始索引为负,则从右往左开始截取 - -1表示倒数第一个, -2表示倒数第二个

    myString="JavaScript";

        console.log(myString.substr(-1,1));//t  表示从倒数第一个开始截取,截取1个字符
        console.log(myString.substr(-2,1));//p  表示从倒数第二个开始截取,截取1个字符
    
        console.log(myString.substr(-6,1));//S  表示从倒数第6个开始截取,截取1个字符
        console.log(myString.substr(-6,2));//Sc  表示从倒数第6个开始截取,截取2个字符
    

    substring(startIndex,endIndex)  获取部分字符串

    截取 起始索引startIndex 到 结束索引endIndex的子字符串,
    结果包含startIndex处的字符,不包含endIndex处的字符。

        //如果省略个数,则自动获取后面所有
         console.log(myString.substring(4));//Script
        //若startIndex或者endIndex为负,则会被替换为0。
        console.log(myString.substring(-1,1));//J
        //若startIndex = endIndex,则返回空字符串。
        console.log(myString.substring(3,3));//返回空
        //若startIndex > endIndex,则执行方法时,两个值会被交换。
        console.log(myString.substring(3,1));//等价于myString.substring(1,3) 

     slice(startIndex,endIndex)   获取部分字符串

    截取 起始索引startIndex 到 结束索引endIndex的子字符串,
    结果包含startIndex处的字符,不包含endIndex处的字符。

        myString="JavaScript";
        console.log(myString.slice(1,3)) //av
        console.log(myString.slice(4,5)) //S
        console.log(myString.slice(4)) //Script  //如果省略个数,则自动获取后面所有
    

    // 基本用法和substring用法一样,不同点如下:

    // stringObj.slice(start, [end])
    // 如果 start 为负,将它作为 length + start处理,此处 length 为数组的长度。
    console.log(myString.slice(-1,3))
    // 如果 end 为负,就将它作为 length + end 处理,此处 length 为数组的长度。
    console.log(myString.slice(2,-3))
    // 如果省略 end ,那么 slice 方法将一直复制到 arrayObj 的结尾。
    // 如果 end 大于 start,不复制任何元素到新数组中。
    //
    // strVariable.substring(start, end)
    // 如果 start 或 end 为 NaN 或者负数,那么将其替换为0。
    // 子字符串的长度等于 start 和 end 之差的绝对值。例如,在 strvar.substring(0, 3) 和 strvar.substring(3, 0) 返回的子字符串的的长度是 3。
    // slice可以对数组操作,substring不行。。。

    split()分割  

     按给定字符串分割,返回分割后的多个字符串组成的字符串数组。

        console.log('split()用法')
        var s="a,bc,d";
        console.log(s.split(","));//["a", "bc", "d"]
        s="a1b1c1d1";
        console.log(s.split("1"));//["a", "b", "c", "d", ""]
    

    John()合并  

    使用您选择的分隔符将一个数组合并为一个字符串

        var myList=new Array("jpg","bmp","gif","ico","png");
        var imgString=myList.join("|");//结果是jpg|bmp|gif|ico|png
    

    split()还可以结合正则表达式

        myString = 'javascript is a good script language';
        console.log(myString.split(/s/)); //javascript,is,a,good,script,language
        //传入s表示要匹配空格,我们将字符串分割为一个数组,如果你要访问某一个,那么可以明确指出:
        console.log(myString.split(/s/)[3]); //good

    字符串大小写转换
    使用您选择的分隔符将一个数组合并为一个字符串

        myString="JavaScript";
        myString = myString.toLowerCase();//javascript
         myString = myString.toUpperCase();//JAVASCRIPT
    

      


    replace用法 

    基础用法

    最核心的易错点:如果要替换全部匹配项,需要传入一个 RegExp 对象并指定其 global 属性。

        //基本用法:
        myString = "javascript is a good script language";
        //在此我想将字母a替换成字母A
        console.log(myString.replace("a","A"));
    

    大家运行后可以看到结果,它只替换了找到的第一个字符,如果想替换多个字符怎么办?
    答案:结合正则表达式,这也是replace的核心用法之一!

        //将字母a替换成字母A 错误的写法  少了/g
        myString = "javascript is a good script language";
        console.log(myString.replace(/a/,"A"));
        //console.log(myString.replace(new RegExp('a','gm'),"A"));
    
        //将字母a替换成字母A  正确的写法 /g表示匹配所有
        myString = "javascript is a good script language";
        console.log(myString.replace(/a/g,"A"));
    

    replace用法2 - 高级用法 特殊标记$ 

    对于正则replace约定了一个特殊标记符$:
    1.$i (i:1-99) : 表示从左到右正则子表达式所匹配的文本。
    2.$&:表示与正则表达式匹配的全文本。
    3.$`(`:切换技能键):表示匹配字符串的左边文本。
    4.$'(‘:单引号):表示匹配字符串的右边文本。
    5.$$:表示$转移。

    $i (i:1-99) : 表示从左到右正则子表达式所匹配的文本

    案例1- 匹配后替换

        //在本例中,我们将把所有的花引号替换为直引号:
        myString = '"a", "b"';
        myString = myString.replace(/"([^"]*)"/g, "'$1'");//寻找所有的"abb"形式字符串,此时组合表示字符串,,然后用'$1'替换
        console.log(myString)   //'a', 'b'
    

    案例2- 匹配后替换

        myString= "javascript is a good script language";
        console.log(myString.replace(/(javascript)s*(is)/g,"$1 $2 fun. it $2"));   //javascript is fun. it is a good script language
    

    案例3 - 分组匹配后颠倒 

        //在本例中,我们将把 "itcast,cn" 转换为 "cn itcast" 的形式:
        myString = "itcast , cn";
        myString = myString.replace(/(w+)s*, s*(w+)/, "$2 $1");
        console.log(myString)
    

    案例4 - 分组匹配后颠倒

        myString = "boy & girl";
        myString.replace(/(w+)s*&s*(w+)/g,"$2 & $1") //girl & boy
        console.log(myString)
    

    $&:表示与正则表达式匹配的全文本。

        myString = "boy";
        myString.replace(/w+/g,"$&-$&") // boy-boy
        console.log(myString)
    

    $`(`:切换技能键):表示匹配字符串的左边文本。

        myString = "javascript";
        myString.replace(/script/,"$& != $`") //javascript != java
        console.log(myString)
    

    $'(‘:单引号):表示匹配字符串的右边文本。

        myString = "javascript";
        myString.replace(/java/,"$&$' is ") // javascript is script
        console.log(myString)
    

    replace用法2 - 高级用法 第二个参数可以是函数 - 最常用 必考点  

    replace第二个参数可以传递函数

        myString = "bbabc";
        myString.replace(/(a)(b)/g, function(){
            console.log(arguments) // ["ab", "a", "b", 2, "bbabc"]
        });

     参数将依次为:
     1、整个正则表达式匹配的字符。
     2、第一分组匹配的内容、第二分组匹配的内容…… 以此类推直到最后一个分组。
     3、此次匹配在源自符串中的下标(位置)。
     4、源自符串
     所以例子的输出是 ["ab", "a", "b", 2, "bbabc"]

    用法举例  首字母大写 -- 一个参数 表示匹配的整个字符串

     //在本例中,我们将把字符串中所有单词的首字母都转换为大写:
        myString = 'aaa bbb ccc';
        myString=myString.replace(/w+/g, function(word){
                    return word.substring(0,1).toUpperCase()+word.substring(1);}
        );
        console.log(myString)   //Aaa Bbb Ccc
    

    用法举例  首字母大写 -- 多个参数 - 第一个表示匹配的整个字符串,后面的表示分组中的内容

        function capitalize(str){
            return str.replace( /(^|s)([a-z])/g , function(m,p1,p2){ return p1+p2.toUpperCase();
            } );
    
        };
        myString = "i am a boy !"
        console.log(capitalize(myString)) //I Am A Boy!
    

    正则表达式基础知识

        //星号(*) : 星号代表匹配它前面一个字符任意遍(0或任意次)
    
        //加号(+): 加号是一个与星号(*)类似的通配符,它也是数量词,表示匹配前面的字符一次或多次(至少一次).
                    //它与星号的差别就在这里,星号可以匹配0次,加号则必须一次以上。
    
        //问号(?): 问号也是一个数量词,它代表匹配前一个字符0或1次。
    
    
        //中括号[]: 中括号用来表示一个字符集合,
                    //如果这个集合有很多元素,如26个字母,数字等,一个个地写在中括号里,未免太麻烦太蠢笨,
                    //这时可以用连字符(hyphen)来表示一个范围,
                    // 如:[a-z]表示小写字母的集合,
                    // [a-zA-Z]表示大小写字母的集合。
                    // 脱字符^ (caret).
                    // 这种写法表示,匹配任何不在该集合中的字符,与上面的用法刚好相反
    
    
        //特殊字符:
        //    w -- (小写w) 表示字母或数字,等价于 [a-zA-Z0-9]
        //    W -- (大写W)非字母且非数字,与w相反 等价于 '[^A-Za-z0-9_]'
        //    s  --  (小写s)匹配一个空格字符,包括:空格,换行,回车,tab,等价于[ 
    
    	f]
        //    S --  (大写S)匹配非空格字符,s的相反 等价于 [^ f
    
    	v]。
        //    d -- 表示10进制数字,等价于 [0-9]
        //    D --	匹配一个非数字字符。等价于 [^0-9]。
    
        //    f	匹配一个换页符。等价于 x0c 和 cL。
        //    
    	匹配一个换行符。等价于 x0a 和 cJ。
        //    
    	匹配一个回车符。等价于 x0d 和 cM。
        //    		匹配一个制表符。等价于 x09 和 cI。
        //    v	匹配一个垂直制表符。等价于 x0b 和 cK。
    
    
    
        //    大括号:{}
        //    大括号的作用是指定重复前面一个字符多少遍:
        //    {N} 重复N遍
        //    {n,m} 重复 n~m 遍
        //    {n,}  至少重复n遍
        //    {,m} 至多重复m遍
    
    
    //定位符:
        //    ^	    匹配输入字符串的开始位置。
        //    $	    匹配输入字符串的结束位置。
        //        匹配一个单词边界,也就是指单词和空格间的位置。//例如, 'er' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。
        //    B	和相反,匹配非单词边界。'erB' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。
    

      

     实战举例

    关键字变色

       大家在一些网站上搜索文章的时候,会发现这么一个现象,就是搜索的关键字会高亮改变颜色显示出来??

       可以用正则表达式来实现

     第1种方法:基于特殊字符$

     document.write("replace使用场景第一种实现 - 特殊字符 - 关键字变色:"+"<br />");
        var myString="传智播客是中国最有前景,口碑最好的IT综合教育培训机构,传智播客的宗旨是:一切为了学生,传智播客在全国有众多分校";
        myString=myString.replace(/(传智播客)/g,"<font color=red>$1</font>");
        document.write(myString+"<br />");
    

      第2种方法:基于函数

     document.write("replace使用场景第2种实现 - 牛逼的函数  - 关键字变色:"+"<br />");
    
        function test(str){
            return "<font color='red'>"+str+"</font>"
        }
    
        myString="传智播客是中国最有前景,口碑最好的IT综合教育培训机构,传智播客的宗旨是:一切为了学生,传智播客在全国有众多分校";
        myString=myString.replace(/(传智播客)/g,test);
        document.write(myString);
    

    字符串扩充

    trim()

    这是一个很常见的函数,他的所用是去掉字符序列左边和右边的空格

    trim是ES5新增的,以前的版本不支持,一般我们在编程的时候不会直接使用ES5,所以必须自己扩充

      String.prototype.trim = function() {
          return this.replace(/(^s*)|(s*$)/g, "");
      }
    

      

     


     

      

  • 相关阅读:
    Centos 7.6搭建Skywalking6.5+es6.2.4
    Skywalking入门介绍,skywalking6.5.0 +mysql (windows) 搭建
    使用springcloud gateway搭建网关(分流,限流,熔断)
    Elastalert
    Docker 部署ELK之Sentinl日志报警
    Docker 部署ELK
    基于sentry的前端错误监控日志系统(部署sentry服务器/前端项目部署)-让前端最快的定位到生产问题
    sentry之二:sentry配置钉钉和email
    sentry之一:sentry安装
    全链路追踪技术选型:pinpoint vs skywalking
  • 原文地址:https://www.cnblogs.com/Abner5/p/6783475.html
Copyright © 2011-2022 走看看