您的位置 : 资讯 > 软件教程 > 详解JS基于递归算法实现网页版计算器

详解JS基于递归算法实现网页版计算器

来源:菜鸟下载 | 更新时间:2025-04-26

本文主要介绍了js基于递归实现网页版计算器的方法,结合实例形式分析了javascript采用递归算法实现网页版计算器的步骤与相关操作技巧,需要的

本文主要介绍了js基于递归实现网页版计算器的方法,结合实例形式分析了javascript采用递归算法实现网页版计算器的步骤与相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。

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

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

这个p放在body中,是计算器的html,number()通过传入不同的数字,区分触发按钮。

 

    
  
   
   
   
登录后复制

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型的数值    }   }  } }}
登录后复制

菜鸟下载发布此文仅为传递信息,不代表菜鸟下载认同其观点或证实其描述。

展开
糖葫芦排序游戏
糖葫芦排序游戏
类型:休闲益智 运营状态:公测 语言:简体中文
闯关
前往下载

相关文章

更多>>

热门游戏

更多>>

手机扫描此二维码,

在手机上查看此页面

关于本站 下载帮助 版权声明 网站地图

版权投诉请发邮件到 cn486com#outlook.com (把#改成@),我们会尽快处理

Copyright © 2019-2020 菜鸟下载(www.cn486.com).All Reserved | 备案号:湘ICP备2022003375号-1

本站资源均收集整理于互联网,其著作权归原作者所有,如有侵犯你的版权,请来信告知,我们将及时下架删除相应资源