51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

js应用:介绍“提取字符串中的数字”的几种方法

js应用:介绍"提取字符串中的数字"的几种方法。我们总结了下一共有三种方法:

  • 直接用parseFloat()函数

  • 使用正则表达式将数字的字符删除掉

  • 使用字符串的match方法

接下来,我们一一解析下,走起吧!

前面带数字,后面非数字,可以直接用parseFloat()函数

我们先了解下parseFloat()函数。

JavaScript parseFloat() 函数

定义和用法

parseFloat() 函数可解析一个字符串,并返回一个浮点数。

该函数指定字符串中的首个字符是否是数字。如果是,则对字符串进行解析,直到到达数字的末端为止,然后以数字返回该数字,而不是作为字符串。

语法


parseFloat(string)

| 参数 | 描述 | |:-------|:-------------| | string | 必需。要被解析的字符串。 |

提示和注释

注意: 字符串中只返回第一个数字。

注意: 开头和结尾的空格是允许的。

注意: 如果字符串的第一个字符不能被转换为数字,那么 parseFloat() 会返回 NaN。

实例

var num1 = parseFloat("5.21元"); //num1 : 5.21

使用正则表达式将数字的字符删除掉

像"你好2022年"这样字符串中只含有一个整型数值的字符串,直接使用正则表达式将数字的字符删除掉就行。来个实例说明下:

var str1 = "你好2021年";
var num2 = str1.replace(/[^\d]/g, " "); 

//num2 : 2021

使用字符串的match方法

match定义和用法

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

注意: match() 方法将检索字符串 String Object,以找到一个或多个与 regexp 匹配的文本。这个方法的行为在很大程度上有赖于 regexp 是否具有标志 g。如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。如果没有找到任何匹配的文本, match() 将返回 null。否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。

实例

var str2 = "89.5+7*5-9/3.0+8.5";
var num3 = str2.match(/\d+(\.\d+)?/g);
console.log(num3); // ["89.5", "7", "5", "9", "3.0", "8.5"]
var num4 = str2.match(/[^\d\.]/g);
console.log(num4); // ["+", "*", "-", "/", "+"]

赞(3)
未经允许不得转载:工具盒子 » js应用:介绍“提取字符串中的数字”的几种方法