字符串方法

字符串转换的三种方法.toString()、String()、“+”拼接
获取字符串长度Length属性
连接字符串:concat()
获取索引值:indexOf()
根据索引值获取单个字符:charAt()
截取字符串:substr(fromIndex,length)
截取字符串:substring[startIndex,endIndex)
字符串分割成字符串数组:split()
数组分割成字符串:join()
es6的新方法:是否包含,开始,结束

  • 字符串转换的三种方法.toString()、String()、“+”拼接
var num= 19; // 19
var myStr = num.toString(); // "19"
var num= 19; // 19
var myStr = String(num); // "19"
var num= 19; // 19
var myStr = "" +num; // "19"
  • 连接字符串:concat() (和数组此方法相同)
    var s1="a";
    var s2="b";
    var s3="c";
    console.log(s1.concat(s2,s3));//abc
    // 等同于:result = s1 + s2 + ... + s
    // 关联记忆:数组中的concat
    var arr = [1, 2, 3];
    console.log(arr.concat(4, 5));//[1,2,3,4,5]
  • 获取索引值: indexOf() (如果没找到返回-1)
    // 常用方法:找到匹配项返回索引值,如果没找到返回-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
    console.log(a1)//2
    console.log(a2)//4
    console.log(a3)//4
    console.log(a4)//-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";
    console.log(myString.substr(1,1));//a          表示从第1个索引值开始截取,截取1个字符
    console.log(myString.substr(1,2));//av         表示从第1个索引值开始截取,截取2个字符
    console.log(myString.substr(1,3));//ava        表示从第1个索引值开始截取,截取3个字符
    console.log(myString.substr(1,4));//avaS       表示从第1个索引值开始截取,截取4个字符

    // 若不指定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(-3,1));//i  表示从倒数第三个开始截取,截取1个字符
    console.log(myString.substr(-4,1));//r  表示从倒数第四个开始截取,截取1个字符
    console.log(myString.substr(-5,1));//c  表示从倒数第五个开始截取,截取1个字符
    console.log(myString.substr(-6,1));//S  表示从倒数第六个开始截取,截取1个字符
    console.log(myString.substr(-7,1));//a  表示从倒数第七个开始截取,截取1个字符
  • 截取字符串:substring[startIndex,endIndex)
   截取 起始索引startIndex  到  结束索引endIndex的子字符串,
   结果包含startIndex处的字符,不包含endIndex处的字符。
   // 获取 av
    myString="JavaScript";
    console.log(myString.substring(1,3));

    // 获取 大写的 S
    myString="JavaScript";
    console.log(myString.substring(4,5));

    // 其他小点:
    // 如果省略个数,则自动获取后面所有
     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)
  • 字符串分割成字符串数组:split()
"hello".split("")   //可返回 ["h", "e", "l", "l", "o"]
"hello".split("", 3) //可返回 ["h", "e", "l"]
  var s="a,bc,d";
    console.log(s.split(","));//["a", "bc", "d"]
    s="a1b1c1d1";
    console.log(s.split("1"));//["a", "b", "c", "d", ""]
  • 把数组中的所有元素放入一个字符串,元素是通过指定的分隔符进行分隔的:join()
  var myList=[1,2,3,4];
   console.log(myList) -----[1,2,3,4]
    var imgString=myList.join(",");------1,2,3,4
    console.log(imgString)
  </script>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,482评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,377评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,762评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,273评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,289评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,046评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,351评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,988评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,476评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,948评论 2 324
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,064评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,712评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,261评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,264评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,486评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,511评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,802评论 2 345

推荐阅读更多精彩内容