本人新手,如果有什么不足的地方,希望可以得到指点

今天尝试用javascript写一个计算器

首先把计算器的按钮做出来,用button做好了,这样可以不用设置太多的样式

<button value="7" >7</button>

按照上面把0-9数字的按钮都搞出来 当然还有+-*/=%这些按钮

顺便给每个按钮添加样式 如下:

<style>

  .short{height:63px;width:55px;float:left;}

</style>

<button value="7" class="short">7</button>

在按钮顶部添加一个屏幕用input的text来做:

<input type="text" id="pingmu" style="height:36px;width:276px;"/><br/>

然后下面的方式进行排版

<-屏幕->

7 8 9  * /

4 5 6 -  %

1 2 3 + =

显示的效果如下

基本上样式上就简单的完成了,现在来解决脚本的问题

为了思路不混淆,先来实现按钮的输出,不考虑计算方面的问题

可以利用每个按钮自带的value属性来获取其值如下:

<button value="7" class="short" onclick="num(this.value)">7</button>

然后写一个num函数

<script>
function num(a){
var pingmu=document.getElementById("pingmu") //获得屏幕对象
pingmu.value=a; //把按钮的值输出出来
}
</script>

虽然屏幕可以成功显示每个按钮按下后的值,但是如果想要按出大于一位的数字比如六十四(64)的时候,你会发现

只能分别按出6 和 4,而按不出64,因此需要添加一个变量用于临时保存显示的值,这个变量就用xianshi来命名好了

每次按下按钮,xianshi变量就会保存按下的值,最后在输出

当然如果你连续按下数字后 再按运算符号时,符号也会被保存,

因此需要判断按钮的值是数字还是符号

如果是数字xianshi变量就保存其值

如果是符号那么只输出符号,并且清空xianshi变量的值

因为如果不清空,按完符号再按数字时,数字就会把以前的值显示出来 比如:按12 + 6

按完后因为前面的值没清空 所以会显示:126的结果

<script>
var xianshi="";
function num(a){
var pingmu=document.getElementById("pingmu");
if(!isNaN(a)){ //判断是否是数字
xianshi+=a;
pingmu.value=xianshi;
}
else{pingmu.value=a;xianshi="";}
}
</script>

然后实现计算功能

思路:声明一个变量jisuan用于保存jisuan的值,然后用eval函数将字符串转变为代码。

当然jisuan的第一个字符不能是符号,因此需要判断第一个按钮是否为符号,代码如下

<script>
var jisuan="";
var xianshi="";
function num(a){
if(jisuan==""&&isNaN(a))return 0; //首次输入值不能为符号
jisuan+=a;
var pingmu=document.getElementById("pingmu");
if(!isNaN(a)){xianshi+=a;pingmu.value=xianshi;}
else{pingmu.value=a;xianshi="";}
} function sum(){ //计算结果函数
if(jisuan=="")renturn0; //首个按钮不能为=
var pingmu=document.getElementById("pingmu");
total=eval(jisuan)
pingmu.value=total;
jisuan="";xianshi="";
}
</script>
<button value="=" class="sum()" onclick="sum()">=</button>

下面实现缓存功能

计算部分就初步完成了,但是缺少了些功能,比如算完3+3得出的结果6,这时希望用6的值继续下次计算时就实现不了

因此需要添加缓存功能,对上面的代码进一步修改

<script>
var xianshi="";
var jisuan="";
var huanchun=""; function num(a){
if(jisuan==""&&huanchun==""&&isNaN(a))return 0;
var pingmu=document.getElementById("pingmu");
if(!isNaN(a)){xianshi+=a;pingmu.value=xianshi;jisuan+=a;huanchun="";}
else{pingmu.value=a;xianshi="";jisuan=jisuan+huanchun+a;huanchun="";}
} function sum(){
if(jisuan=="")renturn0;
document.getElementById("pingmu");
total=eval(jisuan)
pingmu.value=total;
jisuan="";xianshi="";huanchun=total;
}
</script>

大功告成

不过没有删除键,所以再写个删除键吧,这个函数只需要把所有变量的值清空就完成了

function ccc(){
jisuan="";xianshi="";huanchun="";
document.getElementById("pingmu").value="";
}

HTML:

<button value="c" class="short" onclick="ccc()">C</button>

这里函数名不可以用clear,因为会出错,至于为什么我也不知道,可能侵犯了关键字的权益

感觉要是再加点二进制与十进制的转换就更完美了

function ten(){
var total=0,pows=0
var pingmu=document.getElementById("pingmu");
var value=pingmu.value;
var arr=value.split("");
arr=arr.reverse();
for(i=0;i<arr.length;i++){
arr[i]-=0;
pows=Math.pow(2,i);
total+=arr[i]*pows;
}
pingmu.value=total;
jisuan="";xianshi="";
} function two(){
var pingmu=document.getElementById("pingmu");
var value=pingmu.value;
value-=0;
var arr=new Array();
for(i=0;1;i++){
if(value==0)break;
arr[i]=value%2;
value/=2;
value=parseInt(value);
}
arr=arr.reverse();
str=arr.join("");
pingmu.value=str;
xianshi="";jisuan="";
}
<button value="x" class="short" onclick="ten()">ten</button>
<button value="x" class="short" onclick="two()">two</button>

最终效果如下:

博文中不允许有javascript代码所以具体的效果就法显示啦

用javascript写计算器的更多相关文章

  1. JavaScript写计算器

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. JavaScript 写计算器改进版

    <html><head><style> .short{height:50px;width:55px;float:left;}</style></h ...

  3. 用javascript 写个函数返回一个页面里共使用了多少种HTML 标签

    今天我无意间看到一个面试题: 如何用javascript 写个函数返回一个页面里共使用了多少种HTML 标签? 不知你看到 是否蒙B了,如果是我 面试,肯定脑子嗡嗡的响.... 网上搜了搜也没有找到答 ...

  4. JavaScript写在Html页面的<head></head>中

    JavaScript写在Html页面的<head></head>中 ----------------- <html> <head> <style ...

  5. JavaScript写一个连连看的游戏

    天天看到别人玩连连看, 表示没有认真玩过, 不就把两个一样的图片连接在一起么, 我自己写一个都可以呢. 使用Javascript写了一个, 托管到github, 在线DEMO地址查看:打开 最终的效果 ...

  6. javascript写在<head>和<body>里的区别

    Javascript写在哪里?概括起来就是三种形式:1. 内部:Html网页的<body></body>中:2. 内部:Html网页的<head></head ...

  7. 原生javascript写的侧栏跟随效果

    浏览网站时经常看到有的网站上,当一个页面很长的时候,设定侧栏内容会跟随滚动条滚动,我们把这种效果叫做“侧栏跟随滚动”.这种特效对提高网站浏览量.文章点击率.广告点击量都有一定效果. 侧栏跟随滚动的实现 ...

  8. javascript 写一段代码,判断一个字符串中出现次数最多的字符串,并统计出现的次数

    javascript 写一段代码,判断一个字符串中出现次数最多的字符串,并统计出现的次数 function test(){ var bt = document.getElementById(" ...

  9. 用JavaScript写一个区块链

    几乎每个人都听说过像比特币和以太币这样的加密货币,但是只有极少数人懂得隐藏在它们背后的技术.在这篇博客中,我将会用JavaScript来创建一个简单的区块链来演示它们的内部究竟是如何工作的.我将会称之 ...

随机推荐

  1. AJPFX辨析continue与break的区别

    1.break : (1).结束当前整个循环,执行当前循环下边的语句.忽略循环体中任何其它语句和循环条件测试.(2).只能跳出一层循环,如果你的循环是嵌套循环,那么你需要按照你嵌套的层次,逐步使用br ...

  2. 图解HTTP总结

    一.TCP/IP 的分层管理 二.TCP/IP通信传输流 ARP地址解析协议参考:https://www.cnblogs.com/csguo/p/7527303.html 三.各种协议与HTTP协议的 ...

  3. html5 02 随记

    HTML 02 全局通用属性  id  name  class  style 一. 图像标签 标签名:<img  /> 常用属性: Alt -- 代表图像的替代文字 作用: 当图片不显示的 ...

  4. 排序算法C语言实现

    大学有一门课程叫做数据结构,严蔚敏的课本,其中详细介绍了集中经典的排序算法,学习复习反复几次,但是直到现在仍然只记得名字了,所以想记录下来,随时复习直至牢记于心.经常面试的朋友知道,排序算法在面试中出 ...

  5. 如果不需要,建议移除net standard类库中的Microsoft.NETCore.Portable.Compatibility

    使用Microsoft.NETCore.Portable.Compatibility会破坏该类库在Mono和Xamarin平台的兼容性 可能导致的问题 provides a compile-time ...

  6. Java 设计模式之中介者模式

    本文继续23种设计模式系列之中介者模式.   定义 用一个中介者对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使耦合松散,而且可以独立地改变它们之间的交互.   角色 抽象中介者: ...

  7. UVA 818 Cutting Chains 切断圆环链 (暴力dfs)

    题意就是给一张无向图,去掉某些结点,然后连成一条链,问最少去掉几个结点. n很小n<=15,所以直接枚举2^15个状态就行啦. 链的条件是1.无环,2.没有度大于2的点,3.把n个散链连起来需要 ...

  8. Python socket 粘包

    目录 1 TCP的三次握手四次挥手 0 1.1 三次握手 1 1.2 四次挥手 2 2 粘包现象 3 2.1 基于TCP制作远程执行命令操作(win服务端) 4 2.1 基于TCP制作远程执行命令操作 ...

  9. linux文本编辑器-VIM基本使用方法

    vim [OPTION]... FILE... +/PATTERN:打开文件后,直接让光标处于第一个被PATTERN匹配到的行的行首vim + file 直接打开file,光标在最后一行 三种主要模式 ...

  10. alibaba druid监控页面的使用配置

    一.Maven中添加Durid连接池依赖 <!-- druid连接池 --> <dependency> <groupId>com.alibaba</group ...