`
5211422
  • 浏览: 211389 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

js 计算器(二)

阅读更多

简单实现基本运算

 

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>

<HTML>
 <HEAD>
  <TITLE>计算器</TITLE>
  <META content="text/html; charset=gb2312" http-equiv=Content-Type>
  <!--written by GoldHuman li hai-->
  <!--2000.8-->
  <STYLE>BODY {
 BACKGROUND-ATTACHMENT: fixed; BACKGROUND-COLOR: #edf0e1; COLOR: #0001fc; FONT-FAMILY: "宋体", "Arial", "Times New Roman"; FONT-SIZE: 9pt
}
TD {
 FONT-FAMILY: "宋体", "Arial Narrow", "Times New Roman"; FONT-SIZE: 9pt; font-color: #000000
}
</STYLE>

  <SCRIPT language=javascript>
<!--
var endNumber=true
var mem=0
var carry=10
var hexnum="0123456789abcdef"
var angle="d"
var stack=""
var level="0"
var layer=0


//数字键

function inputkey(key)
{
 var index=key.charCodeAt(0);
 if ((carry==2 && (index==48 || index==49))
  || (carry==8 && index>=48 && index<=55)
  || (carry==10 && (index>=48 && index<=57 || index==46))
  || (carry==16 && ((index>=48 && index<=57) || (index>=97 && index<=102))))
 if(endNumber)
 {
  endNumber=false
  document.calc.display.value = key
 }
 else if(document.calc.display.value == null || document.calc.display.value == "0")
  document.calc.display.value = key
 else
  document.calc.display.value += key
}

function changeSign()
{
    if (document.calc.display.value!="0")
     if(document.calc.display.value.substr(0,1) == "-")
         document.calc.display.value = document.calc.display.value.substr(1)
     else
         document.calc.display.value = "-" + document.calc.display.value
}

//函数键

function inputfunction(fun,shiftfun)
{
 endNumber=true
 if (document.calc.shiftf.checked)
  document.calc.display.value=decto(funcalc(shiftfun,(todec(document.calc.display.value,carry))),carry)
 else
  document.calc.display.value=decto(funcalc(fun,(todec(document.calc.display.value,carry))),carry)
 document.calc.shiftf.checked=false
 document.calc.hypf.checked=false 
 inputshift()
}

function inputtrig(trig,arctrig,hyp,archyp)
{
 if (document.calc.hypf.checked)
  inputfunction(hyp,archyp)
 else
  inputfunction(trig,arctrig)
}


//运算符

function operation(join,newlevel)
{
 endNumber=true
 var temp=stack.substr(stack.lastIndexOf("(")+1)+document.calc.display.value
 while (newlevel!=0 && (newlevel<=(level.charAt(level.length-1))))
 {
  temp=parse(temp)
  level=level.slice(0,-1)
 }
 if (temp.match(/^(.*\d[\+\-\*\/\%\^\&\|x])?([+-]?[0-9a-f\.]+)$/))
  document.calc.display.value=RegExp.$2
 stack=stack.substr(0,stack.lastIndexOf("(")+1)+temp+join
 document.calc.operator.value=" "+join+" "
 level=level+newlevel
 
}

//括号

function addbracket()
{
 endNumber=true
 document.calc.display.value=0
 stack=stack+"("
 document.calc.operator.value="   "
 level=level+0
 
 layer+=1
 document.calc.bracket.value="(="+layer
}

function disbracket()
{
 endNumber=true
 var temp=stack.substr(stack.lastIndexOf("(")+1)+document.calc.display.value
 while ((level.charAt(level.length-1))>0)
 {
  temp=parse(temp)
  level=level.slice(0,-1)
 }
 
 document.calc.display.value=temp
 stack=stack.substr(0,stack.lastIndexOf("("))
 document.calc.operator.value="   "
 level=level.slice(0,-1)

 layer-=1
 if (layer>0)
  document.calc.bracket.value="(="+layer
 else
  document.calc.bracket.value=""
}

//等号

function result()
{
 endNumber=true
 while (layer>0)
  disbracket()
 var temp=stack+document.calc.display.value
 while ((level.charAt(level.length-1))>0)
 {
  temp=parse(temp)
  level=level.slice(0,-1)
 }

 document.calc.display.value=temp
 document.calc.bracket.value=""
 document.calc.operator.value=""
 stack=""
 level="0"
}


//修改键

function backspace()
{
 if (!endNumber)
 {
  if(document.calc.display.value.length>1)
   document.calc.display.value=document.calc.display.value.substring(0,document.calc.display.value.length - 1)
  else
   document.calc.display.value=0
 }
}

function clearall()
{
 document.calc.display.value=0
 endNumber=true
 stack=""
 level="0"
 layer=""
 document.calc.operator.value=""
 document.calc.bracket.value=""
}


//转换键

function inputChangCarry(newcarry)
{
 endNumber=true
 document.calc.display.value=(decto(todec(document.calc.display.value,carry),newcarry))
 carry=newcarry

 document.calc.sin.disabled=(carry!=10)
 document.calc.cos.disabled=(carry!=10)
 document.calc.tan.disabled=(carry!=10)
 document.calc.bt.disabled=(carry!=10)
 document.calc.pi.disabled=(carry!=10)
 document.calc.e.disabled=(carry!=10)
 document.calc.kp.disabled=(carry!=10)
    
 document.calc.k2.disabled=(carry<=2)
 document.calc.k3.disabled=(carry<=2)
 document.calc.k4.disabled=(carry<=2)
 document.calc.k5.disabled=(carry<=2)
 document.calc.k6.disabled=(carry<=2)
 document.calc.k7.disabled=(carry<=2)
 document.calc.k8.disabled=(carry<=8)
 document.calc.k9.disabled=(carry<=8)
 document.calc.ka.disabled=(carry<=10)
 document.calc.kb.disabled=(carry<=10)
 document.calc.kc.disabled=(carry<=10)
 document.calc.kd.disabled=(carry<=10)
 document.calc.ke.disabled=(carry<=10)
 document.calc.kf.disabled=(carry<=10)

 
 
}

function inputChangAngle(angletype)
{
 endNumber=true
 angle=angletype
 if (angle=="d")
  document.calc.display.value=radiansToDegress(document.calc.display.value)
 else
  document.calc.display.value=degressToRadians(document.calc.display.value)
 endNumber=true
}

function inputshift()
{
 if (document.calc.shiftf.checked)
 {
  document.calc.bt.value="deg "
  document.calc.ln.value="exp "
  document.calc.log.value="expd"
  
  if (document.calc.hypf.checked)
  {
   document.calc.sin.value="ahs "
   document.calc.cos.value="ahc "
   document.calc.tan.value="aht "
  }
  else
  {
   document.calc.sin.value="asin"
   document.calc.cos.value="acos"
   document.calc.tan.value="atan"
  }
  
  document.calc.sqr.value="x^.5"
  document.calc.cube.value="x^.3"
  
  document.calc.floor.value="小数"
 }
 else
 {
  document.calc.bt.value="d.ms"
  document.calc.ln.value=" ln "
  document.calc.log.value="log "

  if (document.calc.hypf.checked)
  {
   document.calc.sin.value="hsin"
   document.calc.cos.value="hcos"
   document.calc.tan.value="htan"
  }
  else
  {
   document.calc.sin.value="sin "
   document.calc.cos.value="cos "
   document.calc.tan.value="tan "
  }
  
  document.calc.sqr.value="x^2 "
  document.calc.cube.value="x^3 "
  
  document.calc.floor.value="取整"
 }

}
//存储器部分

function clearmemory()
{
 mem=0
 document.calc.memory.value="   "
}

function getmemory()
{
 endNumber=true
 document.calc.display.value=decto(mem,carry)
}

function putmemory()
{
 endNumber=true
 if (document.calc.display.value!=0)
 {
  mem=todec(document.calc.display.value,carry)
  document.calc.memory.value=" M "
 }
 else
  document.calc.memory.value="   "
}

function addmemory()
{
 endNumber=true
 mem=parseFloat(mem)+parseFloat(todec(document.calc.display.value,carry))
 if (mem==0)
  document.calc.memory.value="   "
 else
  document.calc.memory.value=" M "
}

function multimemory()
{
 endNumber=true
 mem=parseFloat(mem)*parseFloat(todec(document.calc.display.value,carry))
 if (mem==0)
  document.calc.memory.value="   "
 else
  document.calc.memory.value=" M "
}

//十进制转换

function todec(num,oldcarry)
{
 if (oldcarry==10 || num==0) return(num)
 var neg=(num.charAt(0)=="-")
 if (neg) num=num.substr(1)
 var newnum=0
 for (var index=1;index<=num.length;index++)
  newnum=newnum*oldcarry+hexnum.indexOf(num.charAt(index-1))
 if (neg)
  newnum=-newnum
 return(newnum)
}

function decto(num,newcarry)
{
 var neg=(num<0)
 if (newcarry==10 || num==0) return(num)
 num=""+Math.abs(num)
 var newnum=""
 while (num!=0)
 {
  newnum=hexnum.charAt(num%newcarry)+newnum
  num=Math.floor(num/newcarry)
 }
 if (neg)
  newnum="-"+newnum
 return(newnum)
}

//表达式解析

function parse(string)
{
 if (string.match(/^(.*\d[\+\-\*\/\%\^\&\|x\<])?([+-]?[0-9a-f\.]+)([\+\-\*\/\%\^\&\|x\<])([+-]?[0-9a-f\.]+)$/))
  return(RegExp.$1+cypher(RegExp.$2,RegExp.$3,RegExp.$4))
 else
  return(string)
}

//数学运算和位运算

function cypher(left,join,right)
{
 left=todec(left,carry)
 right=todec(right,carry)
 if (join=="+")
  return(decto(parseFloat(left)+parseFloat(right),carry))
 if (join=="-")
  return(decto(left-right,carry))
 if (join=="*")
  return(decto(left*right,carry))
 if (join=="/" && right!=0)
  return(decto(left/right,carry))
 if (join=="%")
  return(decto(left%right,carry))
 if (join=="&")
  return(decto(left&right,carry))
 if (join=="|")
  return(decto(left|right,carry))
 if (join=="^")
  return(decto(Math.pow(left,right),carry))
 if (join=="x")
  return(decto(left^right,carry))
 if (join=="<")
  return(decto(left<<right,carry))
 alert("除数不能为零")
 return(left)
}

//函数计算

function funcalc(fun,num)
{
 with(Math)
 {
  if (fun=="pi")
   return(PI)
  if (fun=="e")
   return(E)

  if (fun=="abs")
   return(abs(num))
  if (fun=="ceil")
   return(ceil(num))
  if (fun=="round")
   return(round(num))

  if (fun=="floor")
   return(floor(num))
  if (fun=="deci")
   return(num-floor(num))


  if (fun=="ln" && num>0)
   return(log(num))
  if (fun=="exp")
   return(exp(num))
  if (fun=="log" && num>0)
   return(log(num)*LOG10E)
  if (fun=="expdec")
   return(pow(10,num))

  
  if (fun=="cube")
   return(num*num*num)
  if (fun=="cubt")
   return(pow(num,1/3))
  if (fun=="sqr")
   return(num*num)
  if (fun=="sqrt" && num>=0)
   return(sqrt(num))

  if (fun=="!")
   return(factorial(num))

  if (fun=="recip" && num!=0)
   return(1/num)
  
  if (fun=="dms")
   return(dms(num))
  if (fun=="deg")
   return(deg(num))

  if (fun=="~")
   return(~num)
 
  if (angle=="d")
  {
   if (fun=="sin")
    return(sin(degressToRadians(num)))
   if (fun=="cos")
    return(cos(degressToRadians(num)))
   if (fun=="tan")
    return(tan(degressToRadians(num)))

   if (fun=="arcsin" && abs(num)<=1)
    return(radiansToDegress(asin(num)))
   if (fun=="arccos" && abs(num)<=1)
    return(radiansToDegress(acos(num)))
   if (fun=="arctan")
    return(radiansToDegress(atan(num)))
  }
  else
  {
   if (fun=="sin")
    return(sin(num))
   if (fun=="cos")
    return(cos(num))
   if (fun=="tan")
    return(tan(num))

   if (fun=="arcsin" && abs(num)<=1)
    return(asin(num))
   if (fun=="arccos" && abs(num)<=1)
    return(acos(num))
   if (fun=="arctan")
    return(atan(num))
  }
 
  if (fun=="hypsin")
   return((exp(num)-exp(0-num))*0.5)
  if (fun=="hypcos")
   return((exp(num)+exp(-num))*0.5)
  if (fun=="hyptan")
   return((exp(num)-exp(-num))/(exp(num)+exp(-num)))

  if (fun=="ahypsin" | fun=="hypcos" | fun=="hyptan")
  {
   alert("对不起,公式还没有查到!")
   return(num)
  }
  
  alert("超出函数定义范围")
  return(num)
 }
}

function factorial(n)
{
 n=Math.abs(parseInt(n))
 var fac=1
 for (;n>0;n-=1)
  fac*=n
 return(fac)
}

function dms(n)
{
 var neg=(n<0)
 with(Math)
 { 
  n=abs(n)
  var d=floor(n)
  var m=floor(60*(n-d))
  var s=(n-d)*60-m
 }
 var dms=d+m/100+s*0.006
 if (neg)
  dms=-dms
 return(dms)
}

function deg(n)
{
 var neg=(n<0)
 with(Math)
 {
  n=abs(n)
  var d=floor(n)
  var m=floor((n-d)*100)
  var s=(n-d)*100-m
 }
 var deg=d+m/60+s/36
 if (neg)
  deg=-deg
 return(deg)
}

function degressToRadians(degress)
{
 return(degress*Math.PI/180)
}

function radiansToDegress(radians)
{
 return(radians*180/Math.PI)
}

//界面

//-->
</SCRIPT>
  <!--written by GoldHuman li hai-->
  <!--2000.8-->
  <META content="Microsoft FrontPage 4.0" name=GENERATOR>
 </HEAD>
 <BODY>
  <DIV align=center>
   <FORM name=calc>
    <TABLE border=1 height=250 width=500>
     <TBODY>
      <TR>
       <TD height=50>
        <TABLE width=500>
         <TBODY>
          <TR>
           <TD>
            <DIV align=center>
             <INPUT name=display readOnly size=40 value=0>
            </DIV>
           </TD>
          </TR>
         </TBODY>
        </TABLE>
       </TD>
      </TR>
      <TR>
       <TD>
        <span style="display:none">
         <INPUT CHECKED name=carry  type=radio>十进制
         <INPUT name=bracket readOnly size=3 style="BACKGROUND-COLOR: lightgrey">
         <INPUT name=memory readOnly size=3 style="BACKGROUND-COLOR: lightgrey">
         <INPUT name=operator readOnly size=3 style="BACKGROUND-COLOR: lightgrey">
        </span>
        <TABLE width=500>
         <TBODY>
          <TR>
           <TD>
            <TABLE>
             <TBODY>
              <TR align=middle>
               <TD>
                <INPUT name=k7 onclick="inputkey('7')"
                 style="COLOR: blue" type=button value=" 7 ">
               </TD>
               <TD>
                <INPUT name=k8 onclick="inputkey('8')"
                 style="COLOR: blue" type=button value=" 8 ">
               </TD>
               <TD>
                <INPUT name=k9 onclick="inputkey('9')"
                 style="COLOR: blue" type=button value=" 9 ">
               </TD>
               <TD>
                <INPUT onclick="operation('/',6)" style="COLOR: red"
                 type=button value=" / ">
               </TD>
               <TD>
                <INPUT onclick=backspace() style="COLOR: red" type=button
             value="退格">
               </TD>
              </TR>
              <TR align=middle>
               <TD>
                <INPUT name=k4 onclick="inputkey('4')"
                 style="COLOR: blue" type=button value=" 4 ">
               </TD>
               <TD>
                <INPUT name=k5 onclick="inputkey('5')"
                 style="COLOR: blue" type=button value=" 5 ">
               </TD>
               <TD>
                <INPUT name=k6 onclick="inputkey('6')"
                 style="COLOR: blue" type=button value=" 6 ">
               </TD>
               <TD>
                <INPUT onclick="operation('*',6)" style="COLOR: red"
                 type=button value=" * ">
               </TD>
               <TD>
                <INPUT onclick="document.calc.display.value = 0 "
             style="COLOR: red" type=button value=" ">
               </TD>
              </TR>
              <TR align=middle>
               <TD>
                <INPUT onclick="inputkey('1')" style="COLOR: blue"
                 type=button value=" 1 ">
               </TD>
               <TD>
                <INPUT name=k2 onclick="inputkey('2')"
                 style="COLOR: blue" type=button value=" 2 ">
               </TD>
               <TD>
                <INPUT name=k3 onclick="inputkey('3')"
                 style="COLOR: blue" type=button value=" 3 ">
               </TD>
               <TD>
                <INPUT onclick="operation('-',5)" style="COLOR: red"
                 type=button value=" - ">
               </TD>
               <TD>
                <INPUT onclick=clearall() style="COLOR: red" type=button
             value="全清">
               </TD>
              </TR>
              <TR align=middle>
               <TD>
                <INPUT onclick="inputkey('0')" style="COLOR: blue"
                 type=button value=" 0 ">
               </TD>
               <TD>
                <INPUT onclick=changeSign() style="COLOR: blue"
                 type=button value=+/->
               </TD>
               <TD>
                <INPUT name=kp onclick="inputkey('.')"
                 style="COLOR: blue" type=button value=" . ">
               </TD>
               <TD>
                <INPUT onclick="operation('+',5)" style="COLOR: red"
                 type=button value=" + ">
               </TD>
               <TD>
                <INPUT onclick=result() style="COLOR: red" type=button
                 value=" = ">
               </TD>
              </TR>
             </TBODY>
            </TABLE>
           </TD>
          </TR>
         </TBODY>
        </TABLE>
       </TD>
      </TR></TBODY></TABLE>
   </FORM>
  </DIV>
 </BODY>
</HTML>

分享到:
评论

相关推荐

    jisuanqi.rar_html js计算器_js计算器_计算器_计算器 js_计算器JS

    【标题】"jisuanqi.rar_html js计算器_js计算器_计算器_计算器 js_计算器JS" 提供的是一个基于HTML和JavaScript实现的全功能计算器项目。这个计算器不仅具备基本的加、减、乘、除运算,还可能包括更复杂的计算功能,...

    JavaScript计算器

    在JavaScript计算器项目中,CSS可以用来设置计算器的外观,包括按钮的大小、颜色、边框、间距,以及显示屏的样式等。通过选择器(如ID选择器、类选择器)和盒模型属性(如margin、padding、border),可以精确地调整...

    html+js计算器

    总之,【HTML+JS计算器】是一个基础但实用的项目,有助于初学者理解Web开发的基本原理,包括HTML的结构化、JavaScript的交互性和CSS的美化。通过这个项目,开发者不仅可以掌握前端基础知识,还能锻炼问题解决和代码...

    Extjs 计算器 javascript计算器

    在这个特定的项目中,“Extjs 计算器 javascript计算器”是利用ExtJS的XTemplate功能创建的一个模拟Windows简单计算器的Web应用。XTemplate是ExtJS提供的一种模板引擎,用于动态渲染数据到HTML元素中,使得我们可以...

    HTML+JAVAScript计算器

    HTML+JavaScript计算器是一种基于网页的计算工具,利用HTML(超文本标记语言)构建用户界面,JavaScript处理用户交互和计算逻辑。在这个项目中,HTML用于创建计算器的布局和按钮,而JavaScript则赋予这些按钮功能,...

    js实现简单计算器

    总的来说,实现一个简单的JavaScript计算器涉及HTML布局、JavaScript事件监听、数值和运算符的管理,以及可能的运算符优先级和括号处理。这不仅是对JavaScript基础的练习,也是对逻辑思维和问题解决能力的挑战。通过...

    计算器代码 js + html

    在房贷计算器中,JavaScript可能处理用户输入的数据,如贷款金额、利率、贷款期限,并根据这些参数计算月供、总利息和还款总额。 HTML(HyperText Markup Language)则是网页结构的基础,定义了网页内容的布局和...

    js计算器_js计算器_

    JavaScript计算器是一种常见的网页交互元素,它使用JavaScript编程语言来实现基本的算术运算。这个项目包含HTML、CSS和JS三个主要部分,分别负责计算器的结构、样式和功能逻辑。 首先,我们从HTML文件开始。HTML...

    html编写网页使用javascript计算器

    html编写网页使用计算器 语言:javascript

    js计算器,简易方便按钮

    简单的javascript计算器,实现按键操作,简易方便,初学者适合; 简单的javascript计算器,实现按键操作,简易方便,初学者适合 简单的javascript计算器,实现按键操作,简易方便,初学者适合; 简单的javascript...

    普通简洁计算器js

    简单js计算器,简单明了,搞笑。// 4、定义计算函数 jisuan(),将提取过来的数字字符串转化为数值,并做出相对应的计算, 无参,无返。 function jisuan(){ var num1 = parseFloat(zuobian); var num2 =...

    Harsh Trivedi 的简单 JavaScript 计算器.zip

    简单的 JavaScript 计算器由Harsh Trivedi制作的简单 JavaScript 计算器。概述简单 JavaScript 计算器是一款使用 JavaScript 构建的简单网页计算器。它提供基本的算术运算,帮助用户快速高效地进行计算。用法您可以...

    网页版科学计算器 二进制计算器 在线十六进制计算器.zip

    网页版科学计算器、二进制计算器以及在线十六进制计算器是网络上常见的一类实用工具,主要用于进行数学计算和数字转换。这些计算器通常基于HTML、CSS和JavaScript等前端技术构建,用户无需下载安装,只需在浏览器中...

    完美版JS计算器--内置文档说明

    这个计算器是制作者在其编程学习旅程的第四阶段完成的作品,因此我们可以预期它涵盖了JavaScript(JS)的一些核心概念和高级特性。 首先,让我们聚焦于JavaScript的基础部分。JS是一种广泛用于网页和网络应用的脚本...

    纯javascript制作的简单js计算器效果.zip

    【标题】"纯javascript制作的简单js计算器效果.zip"是一个包含使用JavaScript编程语言实现的简易计算器项目的压缩包。这个项目可能是一个教学资源或者一个初学者的实践作品,它展示了如何利用JavaScript的基本语法和...

    javascript计算器代码

    JavaScript计算器代码是一个基础的编程项目,它展示了如何使用JavaScript实现一个简单的计算器功能。在这个项目中,我们主要会涉及以下几个JavaScript编程知识点: 1. **DOM操作**:JavaScript与HTML交互的关键在于...

    多功能计算器JS版

    标题“多功能计算器JS版”所指的是一款基于JavaScript编写的计算器应用。JavaScript,是一种广泛用于网页和网络应用的脚本语言,它在浏览器端运行,为用户提供交互式的体验。这款计算器不仅具备基本的四则运算功能,...

Global site tag (gtag.js) - Google Analytics