四、字符串

字符串

一、字符串的属性

  • 字符串的属性

    length: 表示字符串的长度

    例如 :

    var str = “howareyou”;
    console.log(str.length);
    console.log(str[0]);  //获取字符串中对应下标的字符
    
  • 注意: ECMAScript 中的字符串是不可变的; 也就是说,字符串一旦创建,它们的值就不能改变.

    例如:

    var str = “亲,包邮哦”;
    str[0] = “唉”; //不会改变
    

    如果要改变某个变量保存的字符串,首先要销毁原来的字符串,然后再用另一个包含新值的字符串填充该变量.

    var str = “Hello”;
    str = str+” world!”;
    

二、字符串的方法

字符串的方法(函数)

var str = 'ab';
  • str.charAt(3); 获取下标为3的字符

  • str.charCodeAt(3); 获取下标为3的字符的编码(ASCII码)

  • String.fromCharCode(94); ASCII编码转换成字符

    该方法是String的静态方法,所以用String调用,

    如:var str = String.fromCharCode(98,99); //可传入多个参数

    ASCII(AmericanStandard Code for Information Interchange,美国标准信息交换代码)

  • str.concat(); 连接字符串

    例如:

       var str1 = “hello”;
    
           var str2 = str1.concat(“ world”);
    
  • 字符串的查找方法

    str.indexOf(“abc”); 查找字符串第一次出现的位置,如果没找到则返回-1

    例如:

    var str = "abcdabcd";
    var subStr = “bcd”;
    var index = str.indexOf(subStr); 
    
  • str.lastIndexOf(“abc”); 查找字符串最后一次出现的位置,如果没找到则返回-1

    例如: var index = str.lastIndexOf(“abc”);

  • str.search(); 正则匹配(返回第一次出现的位置)

    例如:

    var str = ”Abcdabcd";
    var index = str.search(/abc/i);
    

    注: g表示进行全局匹配,i表示匹配的时候忽略大小写

  • str.replace(); 替换字符串

    例如:

    var str = "how are Are are you!";
    //替换一次
    var newStr = str.replace("are", "old are");
    //替换多次
    var newStr = str.replace(/are/g, "x");
    console.log(newStr)
    

    这里的替换只能执行一次,不能够进行全局匹配,如果需要全局匹配,则应使用正则表达式

  • str.substring(start,end); 截取字符串范围是[start,end)

    例如:

    var str=  "Helloworld!";
    console.log(str.substring(2,5));
    

    注:如果只有一个参数, 则表示到字符串最后

  • str.split(separator, howmany); 根据分隔符、拆分成数组

    • separator(字符串或正则表达式)

    • howmany(可以指定返回的数组的最大长度,可以省略)

      注:如果空字符串(“”)用作separator,那么stringObject中的每个字符之间都会被分割。

  • 大小写转换

    str.toLowerCase();把字符串转换成小写

    str.toUpperCase();把字符串转换成大写

三、Math对象

  • Math对象

    Math对象可以用于执行数学任务

  • Math对象的常用函数:

    • Math.round(3.6) //四舍五入
    • Math.random() //返回0-1之间的随机数
    • Math.max(num1, num2) //返回较大的数
    • Math.min(num1, num2) //返回较小的数
    • Math.abs(num) //绝对值
    • Math.ceil(19.3) //向上取整
    • Math.floor(11.8) //向下取整
    • Math.pow(x,y) //x的y次方
    • Math.sqrt(num) //开平方
    • Math.sin(x)//返回数的正弦

四、正则表达式的概念

1、正则表达式修饰符

修饰符 可以在全局搜索中不区分大小写:

修饰符 描述
i 执行对大小写不敏感的匹配。
g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
m 执行多行匹配。

2、正则表达式模式

方括号用于查找某个范围内的字符:

表达式 描述
[abc] 查找方括号之间的任何字符。
[0-9] 查找任何从 0 至 9 的数字。
(x|y) 查找任何以 | 分隔的选项。

3、元字符是拥有特殊含义的字符:

元字符 描述
\d 查找数字。
\D 非数字
\w 数字字母下划线
\W 非数字字母下划线
\s 查找空白字符。
\b 匹配单词边界。
\uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。

4、量词

量词 描述
n+ 匹配任何包含至少一个 n 的字符串。
n* 匹配任何包含零个或多个 n 的字符串。
n? 匹配任何包含零个或一个 n 的字符串。

5、方法

  • match 方法

    使用正则表达式模式对字符串执行查找,并将包含查找的结果作为数组返回。
    stringObj.match(rgExp)

    • 参数
      stringObj
      必选项。对其进行查找的 String 对象或字符串文字。
      rgExp
      必选项。为包含正则表达式模式和可用标志的正则表达式对象。也可以是包含正则表达式模式和可用标志的变量名或字符串文字。
      其余说明与exec一样,不同的是如果match的表达式匹配了全局标记g将出现所有匹配项,而不用循环,但所有匹配中不会包含子匹配项。

    • 实例

      var str="Hello world!"
      document.write(str.match("world") + "<br />")
      document.write(str.match("World") + "<br />")
      document.write(str.match("worlld") + "<br />")
      document.write(str.match("world!"))
      输出:
      world
      null
      null
      world!
       
      var str="1 plus 2 equal 3"
      console.log(str.match(/\d+/g)) // [1,2,3]
      
  • exec 方法

    是一个正则表达式方法。

    该方法用于检索字符串中的正则表达式的匹配。

    该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。
    rgExp.exec(str)

    • 实例
    /e/.exec("The best things in life are free!");
    
  • test 方法

    test() 方法用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回 true,否则返回 false。
    rgexp.test(str)

    • 实例
    var patt = /e/;
    
    patt.test("The best things in life are free!");
    /^1[3-8][0-9]{9}$/.test('15611833906')
    
  • search 方法

    search 方法可使用字符串作为参数。字符串参数会转换为正则表达式:

    返回与正则表达式查找内容匹配的第一个子字符串的位置(偏移位)。
    stringObj.search(rgExp)

    • 实例
    var str="Visit lucky!"
    document.write(str.search(/lucky/i))
    
  • replace 方法

    返回根据正则表达式进行文字替换后的字符串的复制。
    stringObj.replace(rgExp, replaceText)

    • 实例

      <p>替换 "microsoft" 为 "Runoob" :</p>
      <button onclick="myFunction()">点我</button>
      <p id="demo">Visit Microsoft!</p>
      <script>
      function myFunction() {
          var str = document.getElementById("demo").innerHTML; 
          var txt = str.replace(/microsoft/i,"Runoob");
          document.getElementById("demo").innerHTML = txt;
      }
      
  • split 方法

    将一个字符串分割为子字符串,然后将结果作为字符串数组返回。
    stringObj.split([separator[, limit]])

    • 说明
      split 方法的结果是一个字符串数组,在 stingObj 中每个出现 separator 的位置都要进行分解。separator 不作为任何数组元素的部分返回。

    • 实例

      '156118 339\t06'.split(/\s/)
      
  • 正则匹配实例

//.号元字符, 代表除了换行之外的所有单个字符
var pattern = /g..gle/;   //一个点.匹配一个任意的字符
var str = "goagle";
console.log(pattern.test(str));

//*号元字符, 配合其他字符使用, 允许其他字符出现任意多次
// 重复多次匹配, 可以出现任意次, 
var  pattern = /g.*gle/; //.* 匹配0到多个字符
var  str = "google" 
console.log(pattern.test(str)); 

// [ ] : 表示字符可以出现的范围
//[a-z]*表示任意0到多个a-z的字母
var pattern = /g[a-z]*gle/;
var str = "google";
console.log(pattern.test(str));

//非字符:  ^
var pattern = /g[^0-9]*gle/; //可以有任意多个非0-9的字符
var str = "google";
console.log(pattern.test(str)); 
            
//+ 表示至少出现1次
//[A-Z]+: 至少出现一个A-Z的字符
var pattern = /[a-z][A-Z]+/;
var str = "gooGle";
console.log(pattern.test(str)); 
            
//使用元符号匹配
//\w* :匹配任意多个数字字母下划线 , \w : 等价于[a-zA-Z0-9_] 
var pattern = /g\w*gle/;
var str = "gooA3gle";
console.log(pattern.test(str));

//\d 代表数字, 等价于 [0-9]
//\d* 表示任意多个数字
var pattern = /g\d*gle/;
var str = "g3243gle";
console.log(pattern.test(str)); 
            
//\D: 匹配非数字, 相当于[^0-9]
var pattern = /g\Dgle/;
var str = "ga3gle";
console.log(pattern.test(str)); 
            
//\D{7,}: 匹配至少7个非数字, 相当于[^0-9]{7,}
var pattern = /\D{7,}/;
var str = "g3243gle";
console.log(pattern.test(str)); 

/使用锚元字符
// /^ 匹配开始,从头开始匹配
// $/ 匹配结尾,从结尾开始匹配
var pattern = /^google$/;
var str = "google";
console.log(pattern.test(str));
            
// \s 匹配空格
var pattern = /goo\sgle/;
var str = "goo gle";
console.log(pattern.test(str));

//m 多行匹配
var str = "first second\nthird fourth\nfifth sixth";
var patt = /\w+$/gm
var patt = /\w+/gm
console.log(str.match(patt));

正则匹配实例

/*是否带有小数*/
function   isDecimal(strValue )  {  
   var  objRegExp= /^\d+\.\d+$/;
   return  objRegExp.test(strValue);  
}  

/*校验是否中文名称组成 */
function ischina(str) {
    var reg=/^[\u4E00-\u9FA5]{2,4}$/;   /*定义验证表达式*/
    return reg.test(str);     /*进行验证*/
}

/*校验是否全由8位数字组成 */
function isStudentNo(str) {
    var reg=/^[0-9]{8}$/;   /*定义验证表达式*/
    return reg.test(str);     /*进行验证*/
}

/*校验电话码格式 */
function isTelCode(str) {
    var reg= /^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/;
    return reg.test(str);
}

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

推荐阅读更多精彩内容