JavaScript学习总结之String类型

String是字符串的对象包装类型,可以使用String构造函数来创建。
** var stringObject = new String("hello world"); **

String类型的每个实例都有一个length属性,表示字符串中包含多个字符。

String类型的方法
1、字符方法
  • charAt():以单字符字符串的形式返回给定位置的那个字符;
  • charCodeAt():得到的是字符编码;
  • stringValue[]:可以使用方括号加数字索引来访问字符串中的特定字符;
    例如:
var stringValue = "hello world";
 alert(stringValue.stringValue[1]); //"e"
2、字符串操作方法
  • concat():用于将一或多个字符串拼接起来,返回拼接得到的新字符串,但是,在实践中使用得更多的是加号操作符来拼接字符串;
var result = "hello " + "world";
alert(result); //"hello world"
  • slice()、substr()、substring()这三个方法都会返回被操作字符串的一个字符串,而且也都接受一或两个参数。第一个参数都是指定子字符串的开始位置。但是,对于slice()与substring()的第二个参数指定的是子字符串的最后一个字符后面的位置,而substr()的第二个参数指定的是返回的字符个数;
var stringVaule = "hello world";
alert(stringValue.slice(3));//"lo world"
alert(stringValue.substring(3));//"lo world"
alert(stringValue.substr(3));//"lo world"
alert(stringValue.slice(3,7));//"lo w"
alert(stringValue.substring(3,7));//"lo w"
alert(stringValue.substr(3,7));//"lo worl"
  • 当传入的参数是负值得情况下,slice()、substr()、substring()三个方法的执行情况又不一样;slice()会将传入的负值与字符串的长度相加;substr()会将负的第一个参数加上字符串的长度,将负的第二个参数转换为0;substring()会将所有的负值参数都转换为0,一般这个方法会将较小的数作为开始位置,会将较大的数作为结束位置;
var stringVaule = "hello world";
alert(stringValue.slice(-3));//"rld"
alert(stringValue.substring(-3));//"hello world"
alert(stringValue.substr(-3));//"rld"
alert(stringValue.slice(3,-4));//"lo w"
alert(stringValue.substring(3,-4));//"hel"
alert(stringValue.substr(3,-4));//""
3、字符串位置方法
  • indexOf()
  • lastIndexOf()
    这两个方法都接受两个参数,一个是匹配的字符,一个是可选参数,表示从字符串中的哪个位置开始搜索;
4、trim():会创建一个字符串的副本,删除前置以及后缀的所有空格,然后返回结果;
5、字符串大小写转换方法

涉及的方法有4个:toLowerCase()、toLocaleLowerCase()、toUpperCase()、toLocaleUpperCase(),其中,toLowerCase()、toUpperCase()是两个经典的方法,而toLocaleLowerCase()、toLocaleUpperCase()方法则是针对特定地区的实现。

6、字符串的模式匹配方法
  • 1、match(),调用这个方法,本质上与调用RegExp的exec()方法相同,match()方法只接受一个参数,要么是一个正则表达式,要么是一个RegExp对象。
var text = "cat, bat, sat, fat";
var pattern = /.at/;
var matches = text.match(pattern);
  • 2、search(),这个方法的唯一参数与match()方法的参数相同:由字符串或RegExp对象指定的一个正则表达式。search()方法返回字符串中第一个匹配项的索引;如果没有找到匹配项,则返回-1。而且,search()方法始终是从字符串开头向后查找模式。
var text = "cat, bat, sat, fat";
var pos = text.search(/at/);
alert(pos); //1
  • 为了简化替换子字符串的操作,ECMAScript提供了replace()方法。这个方法接受两个参数:第一个参数可以是一个RegExp对象或者一个字符串,第二个参数可以是一个字符串或者一个函数。如果第一个参数是字符串,那么只会替换第一个字符串。要想替换所有字符串,唯一的方法是提供一个正则表达式,而且要指定全局标志,如下所示:
var text = "cat, bat, sat, fat";
var result = text.replace("at","ond");
alert(result); // "cond, bat, sat, fat"
result = text.replace(/at/g,"ond");
alert(result); //"cond, bond, sond, fond"
  • 最后一个和模式匹配有关的方法是split(),这个方法可以基于指定的分隔符将一个字符串分隔成多个子字符串,并将结果放在一个数组中。还可以接受可选的第二个参数,用于指定数组的大小,以便确保返回的数组不会超过既定大小
var colorText = "red,blue,green,yellow";
var colors1 = colorText.split(","); //["red","blue","green","yellow"]
var colors2 = colorText.split(",",2); //["red","blue"]
var colors3 = colorText.split(/[^\,]+/); //["", ",", ",", ",", ""]
7、localeCompare()

与操作字符串有关的最后一个方法是localeCompare(),这个方法比较两个字符串,并返回下列值中的一个:

  • 如果字符串在字母表中应该排在字符串参数之前,则返回一个负数;
  • 如果字符串等于字符串参数,则返回0;
  • 如果字符串在字母表中应该排在字符串参数之后,则返回一个正数;
var stringValue = "yellow";
alert(stringValue.localeCompare("black")); //1
alert(stringValue.localeCompare("yellow")); //0
alert(stringValue.localeCompare("zoo")); //-1
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349

推荐阅读更多精彩内容