JavaScript

Чем можно заменить eval() в javascript? Нужно получить итоговое число в строке "2 * 10 + 5 / 4"

"2 * 10 + 5 / 4" это просто пример, там могут быть разные цифры, операторы.
можно строку с этими значениями
разбить в массив с коректировкой по типам
и сделать расчеты учитывая математические знаки

var array = "2 * 10 + 5 / 4".split( " ");
и тд
АБ
Александр Булатов
16 208
Лучший ответ
Распарсить строку и подсчитать выражение не так то просто, поскольку нужно учитывать приоритеты операций (умножение и деление выше сложения и вычитания).
А если еще и нет пробелов между знаками и операндами то и того сложнее.
Я такую функцию написал. Помимо приоритета операций учитываются отрицательные и вещественные числа (то есть можно вводить десятичную точку). Только вводимая строка не должна иметь пробелов, то есть должна иметь вид "2*10+5/4"
>>>
var a = prompt();
function solve(arg) {
let s = arg;
// разделяем на числа и знаки
let ss = s.split('');
let st1 = [];
for (var i = 0; i < ss.length - 1; i++) {
if ((!isNaN(ss[i]) && (isNaN(ss[i + 1]) && ss[i + 1] != '.')) || ((isNaN(ss[i]) && ss[i] != '.' ) && !isNaN(ss[i + 1]))) {
ss.splice(i + 1,0,' ');
i++;
//console.log(ss[i])
}
}
sss = ss.join('').split(' ');
//отрицательные числа
if (sss[0] == '-') {
let changeFirstABS = -sss[1];
sss[1] = changeFirstABS;
sss.splice(0,1);
}
for (var i = 0; i < sss.length; i++) {
if(sss[i].length >= 2 && isNaN(sss[i])) {
if (sss[i].charAt(1) == '-') {
console.log(-sss[i+1]);
let changeABS = -sss[i+1];
sss[i+1] = changeABS;
}
let t = sss[i].substring(0,1);
sss[i] = t;
}
}
//отрицательные числа
for (var i = 0; i < sss.length; i++) {
if (!isNaN(sss[i]) || sss[i] == '+' || sss[i] == '-') { st1.push(sss[i]) }
else {
console.log(st1);
// умножение
if (sss[i] == '*') {
console.log(' mult ', st1, sss[i - 1], sss[i + 1]);
res = sss[i - 1] * sss[i + 1];
i++;
//console.log('before',st1);
//console.log(st1[st1.length - 1]);
st1[st1.length - 1] = res;
//console.log('after',st1);
}
// деление
if (sss[i] == '/') {
res = sss[i - 1] / sss[i + 1];
i++;
st1[st1.length - 1] = res;
}
}
}
console.log('st1:',st1);
// подсчитываем результат
res = +st1[0];
console.log('first',res);
for (var i = 0; i < st1.length; i++) {
if (st1[i] == '+') {
console.log(true, st1[i + 1]);
res += +st1[i + 1];
console.log('res', res);
}
if (st1[i] == '-') {
res -= +st1[i + 1];
}
}
return res;
}
alert(solve(a));
тут я смотрю мало кто помогает тем у кого нет своего кода
Urmat Kaibyldaev
Urmat Kaibyldaev
20 993