用js做一个计算器(使用JS实现简易计算器)
类别:编程学习 浏览量:2244
时间:2021-11-05 14:33:48 用js做一个计算器
使用JS实现简易计算器使用JS完成简易计算器,供大家参考,具体内容如下
要求:输入的值只能是数字,使用正则表达式
onchange():值改变时执行事件
onblur():鼠标移出时执行事件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>计算器</title> </head> <body> <li style="text-align: center;"> <input type="text" id="1" onkeyup="this.value=this.value.replace(/[^\d]/g,'') " > <select name="select" id="select"> <option value="null">请选择</option> <option value="0">+</option> <option value="1">-</option> <option value="2">*</option> <option value="3">/</option> </select> <input type="text" id="2" onkeyup="this.value=this.value.replace(/[^\d]/g,'') "> = <input type="text" id="3" onkeyup="this.value=this.value.replace(/[^\d]/g,'') "><br><br> </li> <li style="text-align: center;"> <input type="button" id="button"value="计算"> </li> <script> function accAdd(arg1,arg2){ var r1,r2,m; try{ r1=arg1.toString().split(".")[1].length }catch(e){ r1=0 } try{ r2=arg2.toString().split(".")[1].length }catch(e){ r2=0 } m=Math.pow(10,Math.max(r1,r2)) return (arg1*m+arg2*m)/m } Number.prototype.add = function (arg){ return accAdd(arg,this); } function Subtr(arg1,arg2){ var r1,r2,m,n; try{ r1=arg1.toString().split(".")[1].length }catch(e){ r1=0 } try{ r2=arg2.toString().split(".")[1].length }catch(e){ r2=0 } m=Math.pow(10,Math.max(r1,r2)); // last modify by deeka // 动态控制精度长度 n=(r1>=r2)?r1:r2; return ((arg1*m-arg2*m)/m).toFixed(n); } function accMul(arg1,arg2) //乘法 { var m=0,s1=arg1.toString(),s2=arg2.toString(); try{ m+=s1.split(".")[1].length }catch(e){} try{ m+=s2.split(".")[1].length }catch(e){} return Number(s1.replace(".",""))*Number(s2.replace(".","")) / Math.pow(10,m) } //给Number类型增加一个mul方法,调用起来更加方便。 Number.prototype.mul = function (arg){ return accMul(arg, this); } function accli(arg1,arg2){ var t1=0,t2=0,r1,r2; try{ t1=arg1.toString().split(".")[1].length }catch(e){} try{ t2=arg2.toString().split(".")[1].length }catch(e){} with(Math){ r1=Number(arg1.toString().replace(".","")) r2=Number(arg2.toString().replace(".","")) return (r1/r2)*pow(10,t2-t1); } } Number.prototype.li = function (arg){ return accli(this, arg); } document.getElementById('button').onclick=function(){ var num1 =document.getElementById('1').value; var num2 =document.getElementById('2').value; var num3; var op =document.getElementById('select').value; switch(op){ case '0': num3= accAdd(num1,num2); break; case '1': num3= Subtr(num1,num2) ; break; case '2': num3=accMul(num1,num2) ; break; case '3': num3=accli(num1,num2) ; break; } document.getElementById('3').value=num3; } </script> </body> </html>
效果图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
您可能感兴趣
- nodejs八种命令(详细谈谈NodeJS进程是如何退出的)
- js Date对象
- 什么是jsonp格式
- JS中Location
- javaweb购物车案例(js实现模拟购物商城案例)
- python操作json格式(详解python 3.6 安装json 模块simplejson)
- extjs多选下拉框
- python获取json结果保存文本(Python JSON格式数据的提取和保存的实现)
- sqlserver如何生成xml文件(实现SQL Server 原生数据从XML生成JSON数据的实例代码)
- 使用Console调试js脚本
- 用js做一个计算器(使用JS实现简易计算器)
- js的replace的用法
- JS函数前面感叹号的作用
- vue.js开发网站的关键技术(Vue.js项目前端多语言方案的思路与实践)
- JS中prototype
- 纯css和js有什么区别(CSS语法与JSON、JS对象区别比较)
- 2023新国风戏曲教育寒假集训班汇报演出《戏娃闹元宵》图文报道(2023新国风戏曲教育寒假集训班汇报演出戏娃闹元宵图文报道)
- 九儿《狐踪谍影》出演热血女特警,戏份杀青受关注(九儿狐踪谍影出演热血女特警)
- 红色代表什么(红色代表什么寓意)
- 蓝天代表什么(蓝天代表什么生肖)
- 今天要吃什么(今天要吃什么菜)
- 营养餐是什么(学校营养餐是什么)
热门推荐
- css padding简写
- vue 组件如何转换虚拟dom(Vue源码分析之虚拟DOM详解)
- dedecms自定义联动类别方法(DEDECMS点击主栏目默认显示第一个子栏目列表的方法)
- flow布局(详解为什么设置overflow为hidden可以清除浮动带来的影响)
- php array只能放一种类型的数据(浅谈PHP array_search 和 in_array 函数效率问题)
- python中列表remove的用法汇总(对python_discover方法遍历所有执行的用例详解)
- 阿里云服务器可以连接几个面板(阿里云云服务器宝塔面板的安装图文教程详解)
- hadoop集群怎么配置(Hadoop3.2.0集群搭建常见注意事项)
- css样式为什么要有空格(css几种解决inline-block间隙的方案整理)
- php可忽略大小写的模式符(PHP基于timestamp和nonce实现的防止重放攻击方案分析)