数组上的ParseInt()方法

时间:2012-08-30 08:03:25

标签: javascript jquery

我想知道如何从数组中获取数字。我试过它给我NaN错误

<script type="text/javascript">

$(function(){

var Arr = [ 'h78em', 'w145px', 'w13px' ]

alert(parseInt(Arr[0]))


})
</script>

7 个答案:

答案 0 :(得分:3)

尝试

+Arr[0].replace(/\D/g, '');

示例小提琴:http://jsfiddle.net/t6yCV/

正在开始+的工作方式与parseInt()类似,如果您需要使用获得的数字执行某些数学运算,那么这是必要的:实际上

typeof Arr[0].replace(/\D/g,'')  // String
typeof +Arr[0].replace(/\D/g,'') // Number

答案 1 :(得分:3)

尝试:

['h78em', 'w145px', 'w13px']
 .map(function(a){return ~~(a.replace(/\D/g,''));});
 //=> [78, 145, 13]

See also

或使用更精细的String原型扩展:

String.prototype.intsFromString = function(combine){
 var nums = this.match(/\d{1,}/g);
 return !nums ? 0 
         : nums.length>1 ? combine ? ~~nums.join('') 
           : nums.map(function(a){return ~~a;}) 
         : ~~nums[0];
};
// usage
'abc23'.intsFromString();          //=> 23
'3abc121cde'.intsFromString();     //=> [3,121]
'3abc121cde'.intsFromString(true); //=> 3121
'abcde'.intsFromString();          //=> 0
// and ofcourse
['h78em', 'w145px', 'w13px'].map(function(a){return a.intsFromString();});
//=> [78, 145, 13]

答案 2 :(得分:1)

您可以构建一个从字符串构建数字的函数:

function stringToNum(str){
  num = 0;
  for (i = 0; i < str.length; i++) 
    if (str[i] >= '0' && str[i] <= '9') 
      num = num * 10 + parseInt(str[i]);
  return num;
}

jsFiddle:http://jsfiddle.net/8WwHh/

答案 3 :(得分:1)

试试这个:

var Arr = [ 'h78em', 'w145px', 'w13px' ]

function stringToNum(str){
  return str.match(/\d+/g);

}

alert(stringToNum(Arr[0]));

http://jsfiddle.net/8WwHh/1/

答案 4 :(得分:0)

怎么样

alert(parseInt(Arr[0].replace(/[a-z_A-Z]/g,"")));

jsfiddle

答案 5 :(得分:0)

又一个快速而又肮脏的解决方案:

alert(Arr[0].match("\\d+"));

答案 6 :(得分:0)

试试吧,这个正则表达式更好

parseInt('h343px'.replace(/^[a-zA-Z]+/,''),10)