JavaScript计算器网页版实现代码分享_javascript技巧

JavaScript网页计算器代码,该计算器是用DW写的!
HTML篇

<html
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>计算器</title>
<link href="style/calculator.css" rel="stylesheet" type="text/css" />
<script src="JavaScript/calculator.js"></script>>
</head>

<body >
<form id="form1" name="form1" method="post" action="">
 <table width="320" border="1" cellpadding="0" cellspacing="0" class="trb" id="calculator">
  <tr>
   <td height="100" colspan="4" align="left" valign="top"><label for="txt"></label>
   <input name="txt" type="text" class="txt" id="txt" value="0" onfocus="this.blur();"/></td>
  </tr>
  <tr>
   <td width="80" height="40" align="center" valign="middle" onclick="deleteAll();">C</td>
   <td width="80" height="40" align="center" valign="middle" onclick="Backspace();">←</td>
   <td width="80" height="40" align="center" valign="middle" onclick="sign();">±</td>
   <td width="80" height="40" align="center" valign="middle" class="operator" onclick="add();">+</td>
  </tr>
  <tr>
   <td width="80" height="40" align="center" valign="middle" onclick="command(7);">7</td>
   <td width="80" height="40" align="center" valign="middle" onclick="command(8);">8</td>
   <td width="80" height="40" align="center" valign="middle" onclick="command(9);">9</td>
   <td width="80" height="40" align="center" valign="middle" class="operator" onclick="subtract();">-</td>
  </tr>
  <tr>
   <td width="80" height="40" align="center" valign="middle" onclick="command(4);">4</td>
   <td width="80" height="40" align="center" valign="middle" onclick="command(5);">5</td>
   <td width="80" height="40" align="center" valign="middle" onclick="command(6);">6</td>
   <td width="80" height="40" align="center" valign="middle" class="operator" onclick="multiply();">×</td>
  </tr>
  <tr>
   <td width="80" height="40" align="center" valign="middle" onclick="command(1);">1</td>
   <td width="80" height="40" align="center" valign="middle" onclick="command(2);">2</td>
   <td width="80" height="40" align="center" valign="middle" onclick="command(3);">3</td>
   <td width="80" height="40" align="center" valign="middle" class="operator" onclick="divide();">÷</td>
  </tr>
  <tr>
   <td width="80" height="40" align="center" valign="middle" onclick="command(0);">0</td>
   <td width="80" height="40" align="center" valign="middle" onclick="dot();"></td>
   <td height="40" colspan="2" align="center" valign="middle" bgcolor="#CC6600" onclick="equal();">=</td>
  </tr>
 </table>
 <p> </p>
 <p> </p>
</form>
</body>
</html>

 CSS篇
 

@charset "utf-8";
/* CSS Document */

.trb {
 font-family: Georgia, "Times New Roman", Times, serif;
 font-size: 24px;
 color: #FFF;
 background-color: #333;
 text-align: center;
 border: 1px solid #999;
}
.operator {
 background-color: #333;
 font-size: 18px;
 color: #C60;
 font-family: Verdana, Geneva, sans-serif;
}
td:hover{
 font-size: 28px;
 cursor:pointer;
}
.txt {
 height: 100px;
 width: 320px;
 background-color: #333;
 text-align: left;
 vertical-align: bottom;
 color: #FFF;
 font-size: 30px;
}

 JavaScript篇

 //实现计算器功能

//结果
var result = 0;
//显示框中的数(默认为“0”)
var screenNum = "0";
//数的初始输入状态,默认为0;当按了任意运算符键后,数的输入状态变为1
var state = 0;
//防止重复按运算符键
var avoidRepeat = true;
//运算符键(默认为0--等于号)
var operator = 0;

//第一步:获取按键值,并显示在显示框中
function command(num) {
 //获取显示框的值
 var str = String(document.form1.txt.value);
 //对该值进行判断,如果该值不为"0",且输入状态0,则返回前者,否则为""(双重三目运算)
 //两个判断条件:1、显示框中值是否为"0",  2、数的输入状态
 str = (str != "0")?((state == 0)?str:""):"";
 //给当前值追加字符
 str = str + String(num);
 //刷新显示
 document.form1.txt.value = str;
 //按了任意数字键后,数的输入状态变为0
 state = 0;
 //重置防止重复按键
 avoidRepeat = true;
}

//第二步:确保输入的数是合法的,每个数至多只有一个小数点
function dot() {
 var str = String(document.form1.txt.value);
 //若该数前面未接运算符,则返回前值,否则为"0";
 str = (state == 0)?str:"0";
 //Java里String有length()方法,而JS里String有length属性
 for(i=0;i<=str.length;i++) {
 //substr()获取下标从i开始,个数为1个的子串
 if(str.substr(i,1)==".") {
  //当存在小数点时,则程序终止
  return;
 }
 }
 //若无小数点,则在该数后面加上
 str = str+".";
 //刷新显示
 document.form1.txt.value = str;
 //恢复数的初始输入状态
 state = 0;

}

//第三步:处理退格键
function Backspace() {
 var str= String(document.form1.txt.value);
 //若显示框中数不等于"0",则返回str,否则返回""
 str = (str != "0")?str:"";
 //获取子串
 str = str.substr(0,str.length-1);
 //若str不为"",则返回子串str,否则str="0"
 str = (str != "")?str:"0";
 //刷新显示
 document.form1.txt.value = str;

}

//第四步:删除所有
function deleteAll() {
 //显示框设为"0"
 document.form1.txt.value = "0";
 //恢复数的初始输入状态
 state = 0;
 //恢复运算符键,默认为0--等于号
 operator = 0;
}

//第五步:加法
function add() {
 //调用计算函数
 calculate();
 //更改数的输入状态
 state = 1;
 //更改运算符键,1--加号
 operator = 1;

}

//第六步:减法
function subtract() {
 //调用计算函数
 calculate();
 //更改数的输入状态
 state = 1;
 //2--减号
 operator = 2;

}

//第七步:乘法
function multiply() {
 //调用计算函数
 calculate();
 //更改数的输入状态
 state = 1;
 //3--乘号
 operator = 3;

}

//第八步:除法
function divide() {
 //调用计算函数
 calculate();
 //更改数的输入状态
 state = 1;
 //4--除号
 operator = 4;

}

//第九步:正负号
function sign() {
 //5--正负号
 operator = 5;
 //调用计算函数
 calculate();
 //更改数的输入状态
 state = 1;
 //0--等于号
 operator = 0;
 //正负号可以连续按
 avoidRepeat = true;

}

//第十步:等于
function equal() {
 //调用计算函数
 calculate();
 //更改数的输入状态
 state = 1;
 //0--等于号
 operator = 0;

}

//第十一步:计算
function calculate() {
 //获取显示框中的值
 screenNum = Number(document.form1.txt.value);
 if(avoidRepeat) {
 switch(operator){
  case 1:
  result = result + screenNum;
  document.form1.txt.value = result;
  break;
  case 2:
  result = result - screenNum;
  document.form1.txt.value = result;
  break;
  case 3:
  result = result * screenNum;
  document.form1.txt.value = result;
  break;
  case 4:
  if(screenNum == 0){
   //设置显示框的值
   document.getElementById("txt").value="除数不能为0";
   //3s后,执行清屏函数
   setTimeout(clearScreen,3000);
  }else{
   result = result/screenNum;
   document.form1.txt.value = result;
  }
  break;
  case 5:
  result = (-1)*screenNum;
  document.form1.txt.value = result;
  break;
  case 0:
  result = screenNum;
  document.form1.txt.value = result;
  break;

 }
 //当按了运算符键后,不能再按
 avoidRepeat = false;
 }

}

//第十二步:清屏函数
function clearScreen() {
 document.getElementById("txt").value = "0";

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索js
计算器
javascript实现计算器、javascript 计算器、javascript计算器代码、javascript简单计算器、javascript简易计算器,以便于您获取更多的相关知识。

时间: 2024-10-02 11:17:50

JavaScript计算器网页版实现代码分享_javascript技巧的相关文章

Javascript模拟加速运动与减速运动代码分享_javascript技巧

加速运动,即一个物体运动时速度越来越快:减速运动,即一个物体运动时速度越来越慢.现在用Javascript来模拟这两个效果,原理就是用setInterval或setTimeout动态改变一个元素与另外一个元素的距离,如xxx.style.left或xxx.style.marginLeft,然后每次运动后都使速度增加,这样加速运动的效果就出现了,减速运动是同样的道理. 下面是两个示例: 加速运动 复制代码 代码如下: <!DOCTYPE html> <html> <head&g

javascript修改表格背景色实例代码分享_javascript技巧

复制代码 代码如下: <html> <script> //点击当前选中行的时候设置当前行的颜色,同时恢复除当前行外的行的颜色及鼠标事件 function selectRow(target) {      var sTable = document.getElementById("ServiceListTable")      for(var i=1;i<sTable.rows.length;i++) //遍历除第一行外的所有行      {        

javascript实现汉字转拼音代码分享_javascript技巧

js代码 function arraySearch(l1,l2){ for (var name in PinYin){ if (PinYin[name].indexOf(l1)!=-1) { return name; break; } } return false; } 核心代码: var PinYin = {"a":"\u554a\u963f\u9515","ai":"\u57c3\u6328\u54ce\u5509\u54c0\u7

JavaScript实现的图像模糊算法代码分享_javascript技巧

项目中需要用到HTML5模糊图像,以前用GDI,GDI+中都有现成的组件来实现,HTML5中如何实现?1.createImageData()2.getImageData()3.putImageData()以上3个函数即可实现,用法和奥义,自己百度吧,我就不重复叙述了,没多大的意义. 以下是实现模糊算法的JS,其实还有种2B级算法就是分布矩阵,这样效率提高很多倍,不过效果很差,羽化的效果不强.实现代码: 复制代码 代码如下: var mul_table = [        512,512,456

JavaScript中实现map功能代码分享_javascript技巧

/*   * MAP对象,实现MAP功能   *   * 接口:   * size()     获取MAP元素个数   * isEmpty()    判断MAP是否为空   * clear()     删除MAP所有元素   * put(key, value)   向MAP中增加元素(key, value)    * remove(key)    删除指定KEY的元素,成功返回True,失败返回False   * get(key)    获取指定KEY的元素值VALUE,失败返回NULL   *

Javascript常用字符串判断函数代码分享_javascript技巧

具体的解释查看注释吧,这里就不多废话了,直接上代码: 复制代码 代码如下: /* function obj$(id)                      根据id得到对象  function val$(id)                      根据id得到对象的值  function trim(str)                      删除左边和右边空格  function ltrim(str)                    删除左边空格  function rt

原生js实现的贪吃蛇网页版游戏完整实例_javascript技巧

本文实例讲述了原生js实现的贪吃蛇网页版游戏.分享给大家供大家参考.具体实现方法如下: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>原生js写的贪吃蛇网页版游戏</title> </head> <body> </body> <sc

JavaScript中全选、全不选、反选、无刷新删除、批量删除、即点即改入库(在yii框架中操作)的代码分享_javascript技巧

效果展示: 代码实现: 控制器 <?php namespace app\controllers; use Yii; use yii\filters\AccessControl; use yii\web\Controller; use yii\filters\VerbFilter; use app\models\LoginForm; use app\models\ContactForm; //use yii\db\ActiveRecord; use yii\data\Pagination; use

原生JavaScript编写canvas版的连连看游戏_javascript技巧

本文实例为大家分享了JavaScript编写canvas版的连连看游戏的具体实现代码,供大家参考,具体内容如下 效果图: 实现代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <style> #box{ /*border: 1px solid #D1D1D1; */ overflow: hidden; pos