【发布时间】:2017-03-18 22:14:08
【问题描述】:
我正在制作一个计算器并将所有点击的数字和运算符推送/保存到一个数组和一个字符串。
我想知道哪种方法 在这种情况下最好。从输入 OR 制作字符串或数组是我想不到的更好方法。
我想计算数组或字符串。该字符串给出了错误的答案,我不知道如何计算数组。演示计算器如下。
$(document).ready(function(){
var inputArr = [];
var inputStr = '';
$('span').click(function(){
$('#input').append($(this).text());
//push to inputArr
inputArr.push($(this).text());
//add to inputStr
inputStr += $(this).text();
});
//Get result
$('.equals').click(function(){
$('#result').text(inputArr);
$('#result').append("<br/>" + parseInt(inputStr));
});
$('.clear').click(function(){
// clear everything
$('#input').text('');
inputArr = [];
inputStr = '';
});
});
span {
background: #bbb;
border-radius: 2px;
margin: 5px;
padding: .5em;
cursor: pointer;
}
.equals{
width: 30%;
background: #bbb;
border-radius: 2px;
margin: 15px;
padding: .5em;
cursor: pointer;
text-align: center;
font-size: 1.5em;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<span>1</span> <span>2</span> <span>3</span> <span>4</span> <span>5</span>
<br/>
<br/>
<span>6</span> <span>7</span> <span>8</span> <span>9</span> <span>0</span>
<br/><br/>
<span>+</span><span>-</span><span>*</span><span>/</span><span class='clear'>clear</span>
<p class="equals"> = </p>
<p id="input"></p>
<p id='result'></p>
我尝试使用parseInt(inputStr),但它给出了错误的答案。
【问题讨论】:
-
一个简单的解决方案就是使用
eval,但有些人会说 eval 是邪恶的,所以下一个解决方案是解析你的字符串并评估.. 例如。 -> stackoverflow.com/questions/2276021/…
标签: javascript jquery arrays string calculator