JS学习笔记1——不要使用JavaScript内置的parseInt()和Number()函数,利用map和reduce操作实现一个string2int()函数

map/reduce练习题:不要使用JavaScript内置的parseInt()和Number()函数,利用map和reduce操作实现一个string2int()函数。

分析:把一个字符串"13579"先变成Array——[1, 3, 5, 7, 9],再利用reduce()就可以写出一个把字符串转换为Number的函数。

代码如下:

'use strict';

function string2int(s) {
    function str2num(str){
        var strArr = str.split('');               //把字符串分割成字符串数组
        function toInt(data){
            return +data;                  //通过js的弱类型转换,实现字符类型到数字类型的转换
        }
        var numArr = strArr.map(toInt);           //通过map()把字符串数组转换成数字数组
        return numArr;
    }
    var num = str2num(s);
    var res = num.reduce(function (x,y) {        //通过reduce()把数字数组转换成数字量
        return x*10+y;
    });
    return res;
}

// 测试:
if (string2int('12345') === 12345 && string2int('12300') === 12300) {
    if (string2int.toString().indexOf('parseInt') !== -1) {
        alert('请勿使用parseInt()!');
    } else if (string2int.toString().indexOf('Number') !== -1) {
        alert('请勿使用Number()!');
    } else {
        alert('测试通过!');
    }
}
else {
    alert('测试失败!');
}

注:map()是数组Array的一个方法,传入一个指定方法,返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组。

Array的reduce()把一个函数作用在这个Array[x1, x2, x3...]上,这个函数必须接收两个参数,reduce()把结果继续和序列的下一个元素做累积计算,其效果就是:

[x1, x2, x3, x4].reduce(f) = f(f(f(x1, x2), x3), x4)
js中把字符类型转成数字类型的方法主要有三种:转换函数parseInt()、强制类型转换Number()、利用js变量弱类型转换。

你可能感兴趣的:(JavaScript学习)