用javascript写计算器
本人新手,如果有什么不足的地方,希望可以得到指点
今天尝试用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写计算器的更多相关文章
- JavaScript写计算器
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JavaScript 写计算器改进版
<html><head><style> .short{height:50px;width:55px;float:left;}</style></h ...
- 用javascript 写个函数返回一个页面里共使用了多少种HTML 标签
今天我无意间看到一个面试题: 如何用javascript 写个函数返回一个页面里共使用了多少种HTML 标签? 不知你看到 是否蒙B了,如果是我 面试,肯定脑子嗡嗡的响.... 网上搜了搜也没有找到答 ...
- JavaScript写在Html页面的<head></head>中
JavaScript写在Html页面的<head></head>中 ----------------- <html> <head> <style ...
- JavaScript写一个连连看的游戏
天天看到别人玩连连看, 表示没有认真玩过, 不就把两个一样的图片连接在一起么, 我自己写一个都可以呢. 使用Javascript写了一个, 托管到github, 在线DEMO地址查看:打开 最终的效果 ...
- javascript写在<head>和<body>里的区别
Javascript写在哪里?概括起来就是三种形式:1. 内部:Html网页的<body></body>中:2. 内部:Html网页的<head></head ...
- 原生javascript写的侧栏跟随效果
浏览网站时经常看到有的网站上,当一个页面很长的时候,设定侧栏内容会跟随滚动条滚动,我们把这种效果叫做“侧栏跟随滚动”.这种特效对提高网站浏览量.文章点击率.广告点击量都有一定效果. 侧栏跟随滚动的实现 ...
- javascript 写一段代码,判断一个字符串中出现次数最多的字符串,并统计出现的次数
javascript 写一段代码,判断一个字符串中出现次数最多的字符串,并统计出现的次数 function test(){ var bt = document.getElementById(" ...
- 用JavaScript写一个区块链
几乎每个人都听说过像比特币和以太币这样的加密货币,但是只有极少数人懂得隐藏在它们背后的技术.在这篇博客中,我将会用JavaScript来创建一个简单的区块链来演示它们的内部究竟是如何工作的.我将会称之 ...
随机推荐
- Spring注入属性、对象
对Category和Product注入属性,并且对Product对象,注入一个Category对象 一.新建项目 二.导包 三.新建Category类 package com.yyt.pojo; pu ...
- IO流----File,递归,字节流,字符流
要把数据持久化存储,就需要把内存中的数据存储到内存以外的其他持久化设备(硬盘.光盘.U盘等)上. 当需要把内存中的数据存储到持久化设备上这个动作称为输出(写)Output操作. 当把持久设备上的数据读 ...
- git-gui:使用终端打开以后出现错误提示 Spell checking is unavable
参考链接:http://www.lai18.com/content/10706682.html 安装了git-gui,打开以后出现以下提示: Spell checking is unavable: e ...
- put_user
1. put_user Name put_user -- Write a simple value into user space. Synopsis put_user ( x, ptr); A ...
- JavaScript命名——name不能做变量名
使用name作为变量名(var name = ‘’),在IE中未引起bug,在Chrome中引起bug但未明确指出命名错误,而是会报其他错误,故不便于发现. 现象原因: javascript中name ...
- hiho一下 第四十五周 博弈游戏·Nim游戏·二(转成NIm)
Alice和Bob这一次准备玩一个关于硬币的游戏:N枚硬币排成一列,有的正面朝上,有的背面朝上,从左到右依次编号为1..N.现在两人轮流翻硬币,每次只能将一枚正面朝上的硬币翻过来,并且可以随自己的意愿 ...
- 2018.5.4 AndroidStudio遇到的问题
新建项目初出现异常报错 Error:Execution failed for task ':app:preDebugAndroidTestBuild'. > Conflict 发生这类型的错误, ...
- Render渲染函数和JSX
1.Render函数:render是用来替换temlate的,需要更灵活的模板的写法的时候,用render. 官网API地址:https://cn.vuejs.org/v2/guide/render- ...
- 解决在matplotlib使用中文的问题
原生的matplotlib并不支持直接使用中文,而需要修改一下相应的文件,上网搜了下,找到一个最简洁的办法. NO.1 找到matplotlibrc文件 C:\Python26\Lib\site-pa ...
- iOS与JS相互传值与交互
JavaScriptCore是webkit的一个重要组成部分,主要是对JS进行解析和提供执行环境.iOS7后苹果在iPhone平台推出,极大的方便了我们对js的操作.我们可以脱离webview直接运行 ...