javascript提取字符串中数字的几种方法

成熟不是心变老,而是眼泪在眼里打转却还持续微笑。积极的人在每一次忧患中都是看到一个机会,而消极的人则是在每个机会都是会看到某种忧患。

利用js脚本从一串字符串中提取数字有多种方法,下面就来简单的介绍几种常用到的。

js提取字符串中数字的方法

1、利用  parseFloat() 方法提取字符串中的数字。

parseFloat() 方法提取字符串中的数字,有很多的限制。它只能提取开头为数字的字符串中的数字,如果字符串的开头第一个字符为非数字,则会提取失败。

例:

//feiniaomy.com
console.log(parseFloat('1234feiniaomy.com')) //1234
console.log(parseFloat('123.4feiniaomy.com')) // 123.4
console.log(parseFloat('feiniaomy.com1234')); // NaN
console.log(parseFloat('m123.5')); //NaN

2、JS 使用正则提取字符串中的数字

例1:

可以利用正则的方法将字符串中非数字的字符给去掉,留下的就是数字啦。但要注意的是,如果是要想提取数字中有非整数的部份(带有小数点的数),则无法提取小数点。

//feiniaomy.com
var num = '1234feiniaomy.com'.replace(/[^\d]/g, ""); 
console.log(num); //1234
var num2 = '123.4feiniaomy.com'.replace(/[^\d]/g, ""); 
console.log(num2); //1234
var num3 = 'feiniaomy.com1234'.replace(/[^\d]/g, ""); 
console.log(num3); //1234
var num4 = 'm123.5'.replace(/[^\d]/g, ""); 
console.log(num4); //1235

例2:

通过上面的示例,我们可以修改一下正则表达式,并使用 match 方法来调用它。

//feiniaomy.com
var num = '1234feiniaomy.com'.match(/\d+(\.\d+)?/g); 
console.log(num); //['1234']
var num2 = '123.4feiniaomy.com'.match(/\d+(\.\d+)?/g); 
console.log(num2); //['123.4']
var num3 = 'feiniaomy.com1234'.match(/\d+(\.\d+)?/g); 
console.log(num3); //['1234']
var num4 = 'm123.5'.match(/\d+(\.\d+)?/g); 
console.log(num4); //['123.5]
var num4 = 'm123.55sd58sdf56sdf85sdf6e8f5sd6f'.match(/\d+(\.\d+)?/g); 
console.log(num4); //['123.55', '58', '56', '85', '6', '8', '5', '6']

通过上面的示例,可以看出JS将字符串中的所有数字(包括小数)都提取什么,并通过以数组的方式返回,方便我们进行对提现结果的处理。

本文javascript提取字符串中数字的几种方法到此结束。记得三个尊:尊重自已,尊重别人,保持尊严,对自已的行为负责。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
JS获取鼠标点击时的位置

JS获取URL参数

Ajax跨域问题及解决方案(jsonp,cors)

ajax动态加载json数据并详细解析

ajax从JSP传递对象数组到后台的方法