js递归实现网页版计算器

递归实现网页版计算器可以简化代码,设计思路

1、css+html实现计算器的外观,给每个button绑定number(z)事件,传入z的不同来区分触发事件的按钮。

<!--  <style>放入head中-->



   
   

   
   





2、在number(z)方法中,利用DOM的innerHTML实现表达式的实时显示,并用字符串content存储已点击的数字或符号,当点击"="时,调用fact(content)进行计算。

代码如下:

var content; //存储已点击的数字或符号,要定义成全局的,如果定义在number()中,每次content都会被重新赋值
  function number(z) {
    var k=document.getElementById("txt");//获取显示框的 DOM,并缓存在k中
    if(z==14){//如果点击了"="号
      var sum = fact(content);//调用fact()进行计算,并把结果赋值给sum
      content=content+"="+sum;//在要显示的内容后加入"="和sum
      k.innerHTML = content;
      content = null;//将content清空,准备下次计算
    }else{
    //如果没有点击"="号,而是点击的运算符,就需要通过switch把数字转化成运算符
      switch(z){
        case 10: z = '+'; break;
        case 11: z = '-'; break;
        case 12: z = '*'; break;
        case 13: z = '/'; break;    
      }
      //把此时输入的字符存入content
      if(content){
        content+=z.toString();
      }else{
        content=z.toString();
      }
      k.innerHTML = content;//让它实时显示
    }
  }

3、本计算器中递归算法的思路:在fact(content)中,先用content.indexOf("+")判断"+"号是否存在,若存在,则分别递归调用index前后的两个字符串,并让其相加,直到所有串中都找不到"+"后,开始用content.lastIndexOf("-")判断"-"号,后续操作和加号一样,存在则递归index前后的两个字符串,并让其相减,直到找不到减号,就开始判断乘号和除号,直到没有符号后返回parseFloat(content),这里的content是递归调用后的无符号字符串,并不是最开始引入的参数了。

//实现递归计算
function fact(content){ 
  var index = content.indexOf("+");//获取"+"号的index
  if(index != -1){
    return fact(content.substring(0,index))+fact(content.substring(index+1));
    //当找得到“+”号时,分成两部分相加递归
  }else{
    var index2 = content.lastIndexOf("-");//当找不到“+”号时,开始找“-”号
    if(index2 != -1){
      return fact(content.substring(0,index2))-fact(content.substring(index2+1));
      //当找得到“-”号时,分成两部分相减递归
    }else{
      var index3 = content.indexOf("*");//当找不到“-”号时,开始找“*”号
      if(index3 != -1){
        return fact(content.substring(0,index3))*fact(content.substring(index3+1));
        //当找得到“*”号时,分成两部分相乘递归
      }else{
        var index4 = content.lastIndexOf("/");//当找不到“*”号时,开始找“/”号
        if(index4 != -1){
          return fact(content.substring(0,index4))/fact(content.substring(index4+1));
          //当找得到“/”号时,分成两部分相除递归
        }else{
          return parseFloat(content);//当找不到“/”号时,返回这段串的变成float型的数值
        }
      }
    }
  }
} 

以上是全部代码,设计思路中要注意的两点是:

1、加号和乘号用的indexOf(),而减号和除号用的lastIndexOf()

举个例子:content="3-2-1"

它如果用indexOf(),先把串分成fact("3")-fact("2-1"),前面"3"无符号,递归调用fact时返回parseFloat("3"),而后面的递归调用时,会变成parseFloat("2")-parseFloat("1")=1,这个是fact("2-1")的返回值,最终结果是2,这就相当于:3-(2-1)。

如果用lastIndexOf(),它把串分成fact("3-2")-fact("1"),fact("3-2")的返回值是parseFloat("3")-parseFloat("2")=1,这样就实现了从左到右的计算。

除号也是同理:若content="6/3/2"用indexOf(),相当于:6/(3/2),因为加号和乘号不存在顺序问题,因此可以用indexOf()。

2、乘除在判断的内层,加减在判断的外层

由于乘除要先计算,内层的判断会先获得没有符号的串,他们就会先计算。


这个计算器个人觉得可以优化的地方:(大家也可以思考下)

1、给button绑定事件的时候,采用事件代理模式。

2、用到的哪些属性或方法需要考虑浏览器兼容问题。

本人最开始做的是非递归的两个数加减乘除的计算器,后面改进的时候,想做多个数的计算,思考起来就更复杂了。当采用递归来写,代码量比之前小,易阅读,并且思考起来不复杂。感兴趣的可以试一试,喜欢的帮忙点个赞呀,谢谢!


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值