美文网首页
四、字符串

四、字符串

作者: 帅气的Lucky | 来源:发表于2021-09-20 21:59 被阅读0次

字符串

一、字符串的属性

  • 字符串的属性

    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);
}

相关文章

  • Python基础Day3—容器类型之字符串、列表

    字符串 字符串: 使用引号包裹起来的数据就是字符串 字符串定义方式有四种: 单引号字符串: 双引号字符串: 三个单...

  • C++(一)

    一、Hello World 编译 执行 二、字符串 字符串拼接 字符串打印 三、输入输出 四、集合 创建集合 打印...

  • TS:字符串常用自定义工具函数

    第一:返回字符串长度(包含中文的字符串) 第二:返回字符串中文个数 第三:删除字符串中html代码 第四:去除字符...

  • iOS开发 NSString处理:截取字符串 拼接字符串 比较字

    创建示例字符串 一、截取字符串 二、检索和替换 三、比较字符串 四、拼接字符串 五、路径的处理 六、文件的输入和输出

  • NSString字符串的处理(截取、包含、转大小写等)

    一、截取字符串 二、判断字符串是否包含某字段 三、字符串转大/小写 四、删除(替换)指定字符串 五、保留2位小数点...

  • [iOS功能]- NSString字符串的处理(截取、包含、转大

    一、截取字符串 二、判断字符串是否包含某字段 三、字符串转大/小写 四、删除(替换)指定字符串 五、保留2位小数点...

  • 四、字符串

    一、字符串练习 1、编写程序将"jdk"全部变成大写,并输出到屏幕,截取子串“DK”并输出屏幕。 String j...

  • 字符串(四)

    字符串常用函数 在程序开发中,字符串经常需要被处理,例如求字符串的长度、大小写转换等。如果每次处理字符串时,都编写...

  • 四、字符串

    字符串 一、字符串的属性 字符串的属性length: 表示字符串的长度例如 :var str = “howare...

  • js字符串基础知识总结

    一、长度计算,连接 二、字符串截取 三、查找 四、大小写 以上均未改变原有字符串!!!他们只是新建了字符串而已 *...

网友评论

      本文标题:四、字符串

      本文链接:https://www.haomeiwen.com/subject/sldsgltx.html