- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想做一个计算器,但我不知道如何求算术符号通过正确的方式,我得到 nan 因为例如 + 不是数字,但我现在真的无法想象如何通过正确的方式获得或制作它......我正在寻找简单的方法并且只使用 javascript
var num = document.getElementsByTagName("button");
for( var i = 0; i < num.length; i++ ){
num[i].addEventListener("click", getNum);
var x = Number(num[i].value);
var y = Number(num[i].value);
}
var result = document.getElementById("result");
var numsRes = document.getElementById("numsRes");
numsRes.addEventListener("click", getResult)
var plus = document.getElementById("plus");
function getResult(){
// if( )
result.value = parseInt(x) + parseInt(y);
}
function getNum(){
result.value += this.value;
// if( this.value == "+" ){
// result.value += this.value;
// }
}
button{
width: 30px;
height: 30px;
margin: 5px 0;
}
#result{
width: 130px;
height: 30px;
display: block;
}
<div id="calculator">
<input id="result">
<button type="button" value="0">0</button>
<button type="button" value="1">1</button>
<button type="button" value="2">2</button>
<button type="button" value="3">3</button>
<br>
<button type="button" value="4">4</button>
<button type="button" value="5">5</button>
<button type="button" value="6">6</button>
<button type="button" value="7">7</button>
<br>
<button type="button" value="8">8</button>
<button type="button" value="9">9</button>
<button type="button" value="-">-</button>
<button type="button" id="plus" value="+">+</button>
<br>
<button type="button" value="*">*</button>
<button type="button" value="/">/</button>
<button type="button" id="numsRes" value="=">=</button>
<button type="button" value="C">C</button>
</div>
最佳答案
您应该使用 eval()
函数从字符串中获取计算结果。
这是文档的链接:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/eval
您不需要对所有按钮进行参数化来执行操作,因为当您按下“=”时将评估整个字符串。
这是修改代码并添加 clear
功能后的工作片段:
var result = document.getElementById("result");
var num = document.getElementsByTagName("button");
for (var i = 0; i < num.length; i++) {
num[i].addEventListener("click", getNum);
// Deleted x and y vars, not used now !
}
var numsRes = document.getElementById("numsRes");
numsRes.addEventListener("click", getResult);
// Added clear binding
var clearBtn = document.getElementById("clear");
clearBtn.addEventListener("click", clearRes);
function getResult() {
// Modified to add "eval()"
result.value = eval(result.value);
}
// Added clear function
function clearRes() {
result.value = '';
}
function getNum() {
result.value += this.value;
}
button {
width: 30px;
height: 30px;
margin: 5px 0;
}
#result {
width: 130px;
height: 30px;
display: block;
}
<div id="calculator">
<input id="result">
<button type="button" value="0">0</button>
<button type="button" value="1">1</button>
<button type="button" value="2">2</button>
<button type="button" value="3">3</button>
<br>
<button type="button" value="4">4</button>
<button type="button" value="5">5</button>
<button type="button" value="6">6</button>
<button type="button" value="7">7</button>
<br>
<button type="button" value="8">8</button>
<button type="button" value="9">9</button>
<button type="button" value="-">-</button>
<button type="button" id="plus" value="+">+</button>
<br>
<button type="button" value="*">*</button>
<button type="button" value="/">/</button>
<button type="button" id="numsRes" value="">=</button>
<button type="button" id="clear" value="">C</button>
<!-- The 2 above values are "" to not add characters to the string to be evaluated -->
</div>
希望对你有帮助。
关于javascript - javascript中的真实计算器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49841535/
我正在寻找x86 Assembly中pow(real, real)的实现。我也想了解算法的工作原理。 最佳答案 只需将其计算为2^(y*log2(x))即可。 有一个x86指令FYL2X计算y *
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
风格指南的最后一点 http://www.python.org/dev/peps/pep-0008 读... 不要使用 == 将 bool 值与 True 或 False 进行比较。 为什么? 编辑只
我似乎无法完成这件事。我仍然在我的日志中看到 cloudflare IP。目前,我有一个负载均衡器,它位于 Cloudflare 后面。 目前,这是与 forwardfor 相关的块: opt
此代码行选择任何类名不是“id”和“quantity”的 div 内的所有子输入:: $("div.item > div:not(.id,.quantity) > :input").live("key
我在测试真实产品时遇到错误。当我单击购买按钮时,出现错误“此版本的应用程序未配置为市场计费”。 我用这个例子https://github.com/robotmedia/AndroidBillingLi
到目前为止我能找到的所有答案都建议调用 omp_set_num_threads。虽然在大多数情况下这是一个正确的答案,但它对我不起作用。在内部,调用 omp_set_num_threads 会导致创建
假设我有 3 个显示器。如何仅通过其索引获取第二个句柄? EnumDisplayMonitors() 不会工作,因为它也枚举了伪设备,而 EnumDisplayDevices() 没有给我句柄。 最佳
我一直在尝试制作一个简单的小游戏来测试我的逻辑,这是一个简单的迷宫,它很丑,而且到目前为止很糟糕。 引擎工作得很好,考虑到迷宫已经存在(矩阵),它甚至可以愉快,但我无意绘制一堆 map ,这可能是在
Cloudflare 代理包含一个名为 CF-Connecting-IP 的 header 和用户的真实 IP。我想让 traefik 读取这个 header 并用它的内容创建一个 X-Real-Ip
我想要上下文菜单中的不同菜单项,具体取决于我在 JTable 中单击的行 大多数示例并没有真正显示上下文菜单(应该根据上下文 - 所选行进行填充) 我尝试过这个: popupMenu = ne
我有一个对象 callInst。如何获取函数的真实名称而不是 IR 代码中的名称?如果我在我的通行证中运行此代码(Useless 在另一个问题中发布) StringRef get_function_n
我在 Appium 和 iPad 2 上使用了以下所需的功能 DesiredCapabilities capabilities = new DesiredCapabilities(); capabil
根据documentation 我们可以通过以下方式在模拟器上运行我们的 android 项目: cordova 运行 android 或 cordova emulate android 但是如何在真
在 ASP.NET 中,有没有办法获得真正的原始 URL? 例如,如果用户浏览到“http://example.com/mypage.aspx/%2F”,我希望能够获得“http://example.
我的 NSInputStream 遇到问题。这是我的代码: case NSStreamEventHasBytesAvailable: printf("BYTE AVAILABLE\n"
$(selector).click() 结果没有任何反应。 this answer在浏览器控制台中工作,javascript 上下文设置为 iframe,但不是主页: simulateMouseCli
我在我的 AB Micro820 PLC 中设置了 modbus 映射。我在 40001 中有一个数组用于写入,在 42001 中有一个数组用于读取。两者都是 200 个元素和 REAL 类型(32
我正在寻找有关设计契约(Contract)管理数据模型的建议。因此,合约的一般生命周期是: 契约(Contract)已创建并处于“草稿”状态。它可以在内部查看,并且可以进行更改。 契约(Contrac
我正在尝试让我的 WebView fullscreen 达到标准,我知道如何将它拉伸(stretch)到“全屏”,但我想做的是当您长按 WebView 并选择全屏选项时,创建全屏。有谁知道该怎么做?
我是一名优秀的程序员,十分优秀!