在返回作为字符串参数传递的值时使用eval()的正确方法

时间:2015-12-31 11:41:41

标签: javascript string eval calculator

我将字符串参数传递给 calculate()函数。我需要将它们作为计算值返回。以下哪种形式我正确使用 eval()

数据:

<asp:CheckBox runat="server" ID="NewUser" OnCheckedChanged="UpdateOptions" AutoPostBack="true"/>

第一个版本:

var nums = ['2','3','1'], sum = ['+']; 

第二版:

function calculate(a,b,c,d,e)
{
        console.log('Calculating...(plus separators): '+a+' '+b+' '+c+' '+d+' '+e);
        console.log('Calculating...(comma separators): ',a,' ',b,' ',c,' ',d,' ',e);

        console.log('a :',a);
        console.log('b :',b);
        console.log('c :',c);
        console.log('d :',d);
        console.log('e :',e);
    return eval(a+b+c+d+e);
};
console.log('RESULT: ',calculate(nums[0],sum[0], nums[1],sum[0], nums[2]));

控制台显示“结果:6”“精确结果:231”

哪一个是正确的,如果有的话?在我看来,第一个(“结果6”)没问题,但我宁愿确定。

PS 我使用 eval(),原因我将数学表达式传递为字符串“2 + 3-(4 * 3)/ 7”并想要它要计算。某种简单的计算器解析器

P.S#2 我使用了数组,最终导致我将更多数组元素传递给此函数。

__________________________________________________________________________

修改

现在是否正确使用 eval()

function calculateP(a,c,e)
{
        console.log('Calculating...(plus separators): '+a+' '+c+' '+e);
        console.log('Calculating...(comma separators): ',a,' ',c,' ',e);

        console.log('a: ',a);
        console.log('c: ',c);
        console.log('e: ',e);
    return eval(a+c+e);
};
console.log('precise RESULT: ',calculateP(nums[0], nums[1], nums[2]));

3 个答案:

答案 0 :(得分:2)

我真的相信你几乎可以在任何地方避免eval,但如果你做了一些不好的事情 - 做得好!

var expression = '2 + 3 - (4 * 3) / 7';

console.log(eval(expression));

数学运算?简单!

function cos(input) {
  return Math.cos(input);
}

function ln(input) {
  return Math.log(input);
}

var expression = '2 + 3 - cos(4 * 3) / ln(7)';

console.log(eval(expression));

你在使用eval做的事情是绝对奇怪的,并且违背了eval的性质。

答案 1 :(得分:1)

嗨,你必须使用如下:

var nums = ['2','3','1'], sum = ['+']; 
function calculate(nums)
{
  var res =0;
  for(var i=0;i<nums.length;i++){
    res= res+(parseInt(nums[i]));
  }
    return res;
};

 console.log('RESULT: ',calculate(nums))

答案 2 :(得分:1)

仅举例说明如何处理字符串和一些没有eval()的值。

&#13;
&#13;
var operators = {
        '+': function (a, i) {
            a[i - 1] += a.splice(i, 2)[1];
            return true;
        },
        '*': function (a, i) {
            a[i - 1] *= a.splice(i, 2)[1];
            return true;
        },
        '(': function (a, i) {
            var j = i + 1,
                b;

            while (j < a.length) {
                if (a[j] === ')') {
                    b = a.splice(i + 1, j - i);
                    b.pop();
                    a[i] = calculate(b);
                    return true;
                }
                if (a[j] === '(') {
                    return false;
                }
                j++;
            }
        },
        ')': 0
    },
    precedence = ['(', '*', '+'];

function split(s) {
    var a = s.split(''),
        i = 1;

    while (i < a.length) {
        if (!(a[i - 1] in operators || a[i] in operators)) {
            a[i - 1] += a.splice(i, 1)[0];
            continue;
        }
        i++;
    }
    return a.map(function (b) {
        return b in operators ? b : Number(b);
    });
}

function calculate(a) {
    while (a.length > 1) {
        precedence.some(function (b) {
            return a.some(function (c, i) {
                if (b === c) {
                    return operators[b](a, i);
                }
            });
        });
    }
    return a[0];
}

document.write(calculate(split('12+23*37')) + '<br>'); // 863
document.write(calculate(split('12+23*(2+(3*4)+5)*37')) + '<br>'); // 16181
&#13;
&#13;
&#13;