js练习计算器,支持鼠标点击、键盘操作

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>计算器2.2</title> </head> <body> <input id="a1" disabled="disabled" />
<input id="a2" disabled="disabled" />
<input id="a3" disabled="disabled" /> <p id="counter"></p> <script type="text/javascript">
function addnum(id)
{
b2 = document.getElementById("a2").value;
if(!b2){
document.getElementById("a1").value += id;
}else{
document.getElementById("a3").value += id;
}
} function addtype(id)
{
b1 = document.getElementById("a1").value;
if(!b1){
alert("请输入数字1");
return false;
}
if(id=='*'){
type = '×';
}else if(id=='/'){
type = '÷';
}else{
type = id;
}
document.getElementById("a2").value = type;
} function backspace()
{
b1 = document.getElementById("a1").value;
b2 = document.getElementById("a2").value;
b3 = document.getElementById("a3").value; if(b3){
b3 = b3.substring(0,b3.length-1);
document.getElementById("a3").value = b3;
}else if(b2){
b2 = b2.substring(0,b2.length-1);
document.getElementById("a2").value = b2;
}else if(b1){
b1 = b1.substring(0,b1.length-1);
document.getElementById("a1").value = b1;
}
} function clean()
{
document.getElementById("a1").value="";
document.getElementById("a2").value="";
document.getElementById("a3").value="";
} function suan()
{
var b1 = document.getElementById("a1").value;
var b2 = document.getElementById("a2").value;
if(b2=="×"){
b2 = "*";
}else if(b2=="÷"){
b2 = '/';
}
var b3 = document.getElementById("a3").value;
var bbb = new Array(["+"],["-"],["*"],["/"]); if(!b1){
alert("请输入数字1");
return false;
}
if(b2!=bbb[0] && b2!=bbb[1] && b2!=bbb[2] && b2!=bbb[3]){
alert("请输入运算符");
return false;
}
if(!b3){
alert("请输入数字2");
return false;
}
if(b2==bbb[0]){
var b4=Number(b1)+Number(b3);
}
else if(b2==bbb[1]){
var b4=Number(b1)-Number(b3);
}
else if(b2==bbb[2]){
//js乘法不精确会有很多小数点,整体乘一个数再除去它
b1 = Number(b1)*10000;
b3 = Number(b3)*10000;
b4=b1*b3/100000000;
b1 = b1/10000;
b3 = b3/10000;
}
else if(b2==bbb[3]){
if(b3==0){
b4="[除数不能为零]";
}else{
b4 = Math.round(Number(b1)/Number(b3));
var b5=Number(b1)%Number(b3);
b4=b4+" 余数"+b5;
}
}
if(b2=="*"){
b2 = "×";
}else if(b2=="/"){
b2 = '÷';
}
document.getElementById("counter").innerHTML = b1+b2+b3+"="+b4;
document.getElementById("a1").value="";
document.getElementById("a2").value="";
document.getElementById("a3").value="";
} //keyCode对应键位
keyarr = new Array()
//数字
keyarr[48] = keyarr[96] = "0";
keyarr[49] = keyarr[97] = 1;
keyarr[50] = keyarr[98] = 2;
keyarr[51] = keyarr[99] = 3;
keyarr[52] = keyarr[100] = 4;
keyarr[53] = keyarr[101] = 5;
keyarr[54] = keyarr[102] = 6;
keyarr[55] = keyarr[103] = 7;
keyarr[56] = keyarr[104] = 8;
keyarr[57] = keyarr[105] = 9;
keyarr[110] = keyarr[190] = ".";
//运算符
keyarr[107] = "+";
keyarr[109] = "-";
keyarr[106] = "*";
keyarr[111] = "/";
//退格
keyarr[8] = "backspace";
//结果
keyarr[13] = "="; /*键盘事件*/
var isPiss = 0;
document.onkeydown = function(event) {
var e = event || window.event || arguments.callee.caller.arguments[0];
id = keyarr[e.keyCode];
if(id){
if(id=="+" || id=="-" || id=="*" || id=="/"){ //运算
addtype(id);
}else if(id=="backspace"){ //退格
backspace();
}else if(id=="="){ //结果
suan();
}else{ //输入数字
addnum(id);
}
}
};
</script> <style>
.clear {clear:both; height:0 !important; width:0 !important; overflow:hidden; font-size:0;}
.jisuanqi {width:303px; height:450px; background:#000; overflow:hidden; -webkit-user-select:none; -moz-user-select:none; -ms-user-select:none; user-select:none; font-family:"Microsoft Yahei";}
.jrow {padding-bottom:5px;}
.num, .type {width:72px; height:86px; overflow:hidden; line-height:86px; text-align:center; float:left; color:#fff; font-size:38px; cursor:pointer;}
.num {background:#343432; margin-right:5px;}
.num:active {background:#181818;}
.type {background:#181818;}
.type:active {background:#343432;}
.clean, .backspace {width:149px; height:86px; overflow:hidden; line-height:86px; text-align:center; color:#fff; font-size:38px; cursor:pointer;}
.clean {background:#343432; float:left;}
.clean:active {background:#181818;}
.backspace {background:#181818; float:right;}
.backspace:active {background:#343432;}
</style> <div class="jisuanqi">
<div class="jrow">
<div class="num" onclick="addnum(7)">7</div>
<div class="num" onclick="addnum(8)">8</div>
<div class="num" onclick="addnum(9)">9</div>
<div class="type" onclick="addtype('/')">÷</div>
<div class="clear"></div>
</div> <div class="jrow">
<div class="num" onclick="addnum(4)">4</div>
<div class="num" onclick="addnum(5)">5</div>
<div class="num" onclick="addnum(6)">6</div>
<div class="type" onclick="addtype('*')">×</div>
<div class="clear"></div>
</div> <div class="jrow">
<div class="num" onclick="addnum(1)">1</div>
<div class="num" onclick="addnum(2)">2</div>
<div class="num" onclick="addnum(3)">3</div>
<div class="type" onclick="addtype('-')">-</div>
<div class="clear"></div>
</div> <div class="jrow">
<div class="num" onclick="addnum('.')">.</div>
<div class="num" onclick="addnum(0)">0</div>
<div class="num" onclick="suan()">=</div>
<div class="type" onclick="addtype('+')">+</div>
<div class="clear"></div>
</div> <div class="jrow">
<div class="clean" onclick="clean()">C</div>
<div class="backspace" onclick="backspace()">←</div>
<div class="clear"></div>
</div>
</div> </body>
</html>

  

js练习计算器的更多相关文章

  1. 使用html+css+js实现计算器

    使用html+css+js实现计算器,开启你的计算之旅吧 效果图: 代码如下,复制即可使用: <!DOCTYPE html><html lang="en"> ...

  2. JS中 计算器的简单制作

    今天学习的是JS中的if语句,除此之外老师还教给我们switch语句的用法, 我们用来写了简单计算器的算法,如下: <script> var a=prompt("请输入一个数字& ...

  3. 纯js房贷计算器开源

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. JS简易计算器的实现,以及代码的优化

    用JS实现简易计算器 首先创建结构和样式 <!DOCTYPE html> <html lang="en"> <head> <meta ch ...

  5. JS实现计算器,带三角函数,根号

    极简主义网页计算器. 实现了按键特效,可响应键盘按键,实时显示计算结果. 可切换模式,拓展高级功能,包括根号.三角函数.括号等. 效果如下: 代码如下: html: <!DOCTYPE html ...

  6. js做计算器

    js文档: function count(){ var a var txt1=document.getElementById("txt1").value;//获取第一个输入框的值 ...

  7. js存款计算器原生小demo

    大家好,本人是初入前端的一枚程序猿,深知js底层开发的重要性,这也是我的软肋所在(曾经以为),渐渐的明白了一个道理,饭要一口口吃,路要一步步走,这也是我想告诉给所有刚刚进入IT行业的技术员们,沉下心, ...

  8. JS作计算器

    JavaScript制作计算器 <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  9. js jq计算器

    <html><head><meta http-equiv="Content-type" content="text/html; charse ...

随机推荐

  1. 教你判断一个APP页面是原生的还是H5页面 。(还没看)

    来源:https://www.25xt.com/appdesign/11851.html 刚好是周末,无意之间学堂君在收集相关资料的时候,发现有部分童鞋在问<如何判断一个APP页面是不是H5页面 ...

  2. postman-3断言

    用例3A原则: arrange:初始化测试对象 act:操作.接口测试中通过不同的参数调用接口. assert:断言 snippets提供了一些断言的使用方法. 在新版的postman中,test中方 ...

  3. 利用spring的CommonsMultipartResolver上传文件

    1.CommonsMultipartResolver是spring里面提供的一个上传方式,效率我不知道,但是加入spring容器管理还是很不错的. 2.先看依赖包pom.xml <project ...

  4. Linux操作系统-基本命令(二)

    Linux操作系统基本命令 文件操作类命令 – ln命令 另外一种链接方式称为符号链接(软链接),是指一个文件指向另外一个文件的文件名.软链接类似于Windows系统中的快捷方式.软链接由ln -s命 ...

  5. mybatis一对多关联查询+pagehelper->分页错误

    mybatis一对多关联查询+pagehelper->分页错误. 现象: 网上其他人遇到的类似问题:https://segmentfault.com/q/1010000009692585 解决: ...

  6. All sentinels down, cannot determine where is mymaster master is running...

    修改配置的哨兵文件 vim /sentinel.conf 将保护模式关闭

  7. cpu真实核数

    判断依据: 1.具有相同core id的cpu是同一个core的超线程. 2.具有相同physical id的cpu是同一颗cpu封装的线程或者cores. 英文版: 1.Physical id an ...

  8. 在ubuntu14.04上搭建OpenVPN服务

    简介 在连接了不可信的网络环境后,让手机或者计算机安全的访问互联网,使用虚拟专用网络(Virtual Private Network,VPN)是一个解决办法.OpenVPN是一个SSL VPN完整解决 ...

  9. Java 目标

    Java 技术 其次掌握的技能树主要有三个方面:第一个是基础,比如对集合类,并发包,IO/NIO,JVM,内存模型,泛型,异常,反射,等有深入了解,最好是看过源码了解底层的设计.比如一般面试都会问Co ...

  10. Struts2 学习记录-1--Struts2中的配置文件

    目录 1. web.xml 2. struts.xml 3. struts.properties文件 4.注解式开发 5.与Spring框架集成的配置 主要涉及3个配置文件:web.xml.strut ...