在返回作为字符串参数传递的值时使用eval()的正确方法
Correct method of using eval() when returning values passed as string parameters
我将string参数传递给calculate()函数。我需要将它们作为计算值返回。在以下哪种形式中,我正确使用了eval()?
数据:
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]));
第二个版本:
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]));
控制台显示"RESULT:6"和"精确RESULT:231"。
哪一个是正确的,如果有的话?在我看来,第一个("RESULT 6")是可以的,但我更愿意确定。
p.S我使用了eval(),因为最初我将以字符串"2+3-(4*3)/7"的形式传递数学表达式,并希望对其进行计算。某种简单的计算器解析器
p.S#2我使用了数组,因为最终我将向该函数传递更多的数组元素。
__________________________________________________________________________
编辑
现在是否正确使用了eval()?
function plus(a,b) {
return a+b;
}
function minus(a,b) {
return a-b;
}
var expression = 'minus(plus(2, 3),minus(5,3))';
console.log('(2+3)-(5-3) ',eval(expression));
expression = 'plus(plus(2, 3),minus(5,3))';
console.log('(2+3)+(5-3) ',eval(expression));
我真的相信你几乎可以在任何地方避免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的本性。
嗨,你必须像下面这样使用:
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))
只是一个如何在没有eval()
的情况下处理字符串和一些值的示例。
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
相关文章:
- 递归使用 eval() 是检查程序执行的好方法吗?
- javascript eval方法语法
- 使用 eval 从字符串创建函数的不同方法
- 使用 eval() 的替代方法
- 如何将包含在 eval 方法中的两个文件作为线程运行
- 如何在不使用 eval 的情况下使不存在的(非成员,非全局)方法可调用
- 有没有一种方法可以在JavaScript中执行类似于window.eval()的jQuery
- 在返回作为字符串参数传递的值时使用eval()的正确方法
- 我们可以在 JavaScript 中使用 eval 方法创建 HTML 标签吗?
- 利用JavaScript's eval()方法
- 是否有任何非eval方法可以创建具有运行时确定名称的函数
- 有没有一种方法可以在不进行eval的情况下输入Highchart系列数据
- 在不使用eval的情况下在方法函数中传递固定参数
- 对象的Eval方法
- Javascript,可以在没有 eval 的情况下传递未声明的方法参数
- 使用eval将变量分配给方法.否则我该怎么做
- 替换 eval() 方法
- JavaScript,在不使用eval(Revearing模式)的情况下,将私有函数作为公共方法内的字符串调用
- Javascript:有没有一种方法可以使用字符串作为回调,而不需要eval()
- javascript中的eval方法