文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

javascript如何实现计算器功能

2023-06-25 11:47

关注

这篇文章给大家分享的是有关javascript如何实现计算器功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

1、计算器功能介绍

可以实现数据的加(+),减(-),乘(*),除(/),取余运算(%),以及实现数据的删除(Del)和清空功能(C)。

2、计算器页面设计

1、导航栏部分

{  "navigationBarBackgroundColor": "#fff",  "navigationBarTextStyle": "black",  "navigationBarTitleText": "计算器"}

2、数据部分

data:{  //  data中只放置初始数据  num:"1",  op:" "//记录运算符号 }

3、index.wxml布局页面

<view class="result">    <view class="result-num">{{num}}</view>    <view class="result-op">{{op}}</view></view><view class="btns">  <view>    <view hover-class="bg" bindtap="reSetBtn">C</view>    <view hover-class="bg" bindtap="delBtn">Del</view>    <view hover-class="bg" bindtap="opBtn" data-val="%">%</view>    <view hover-class="bg" bindtap="opBtn" data-val="/">/</view>  </view>  <view>    <view hover-class="bg" bindtap="numBtn" data-val="7">7</view>    <view hover-class="bg" bindtap="numBtn" data-val="8">8</view>    <view hover-class="bg" bindtap="numBtn" data-val="9">9</view>    <view hover-class="bg" bindtap="opBtn" data-val="*">*</view>  </view>  <view>    <view hover-class="bg" bindtap="numBtn" data-val="4">4</view>    <view hover-class="bg" bindtap="numBtn" data-val="5">5</view>    <view hover-class="bg" bindtap="numBtn" data-val="6">6</view>    <view hover-class="bg" bindtap="opBtn" data-val="-">-</view>  </view>  <view>    <view hover-class="bg" bindtap="numBtn" data-val="1">1</view>    <view hover-class="bg" bindtap="numBtn" data-val="2">2</view>    <view hover-class="bg" bindtap="numBtn" data-val="3">3</view>    <view hover-class="bg" bindtap="opBtn" data-val="+">+</view>  </view>  <view>    <view hover-class="bg" bindtap="numBtn" data-val="0">0</view>    <view hover-class="bg" bindtap="doBtn" data-val=".">.</view>    <view hover-class="bg" bindtap="opBtn" data-val="=">=</view>    </view></view>

4、index.css样式页面

page{  display: flex;  flex-direction: column;  height: 100%;}.result{  flex: 1;  background: #f3f6fe;  position: relative;}.result-num{  position: absolute;  font-size: 20pt;  bottom: 5vh;  right: 3vw;} .result-op{  position: absolute;  font-size: 15pt;  bottom: 1vh;  right: 3vw;}.btns{  flex: 1;  display: flex;  flex-direction: column;  font-size: 17pt;  border-top: 1rpx solid #ccc;  border-left: 1rpx solid #ccc;}.btns>view{  flex: 1;  display: flex;}.btns>view>view{  flex-basis: 25%;  border-bottom: 1rpx solid #ccc;  border-right: 1rpx solid #ccc;  box-sizing: border-box;  display:flex;  align-items: center;  justify-content: center;}.btns>view:last-child>view:first-child{  flex-basis: 50%;}.btns>view:first-child>view:first-child{  color:#f00;}.btns>view>view:last-child{  color: #fcBe00;}.bg{  background: #eee;}

5、运行结果

javascript如何实现计算器功能

3、功能实现部分

1、删除功能

其中substr()函数中两个参数,第一个表示截取开始的位置,第二个表示截取的长度

delBtn:function(e){    var num=this.data.num.substr(0,this.data.num.length-1);    this.setData({num:num===""? "0":num})  }

2、清空功能

 reSetBtn:function(e){    //全部变成初始状态    this.result=null;    this.isClear=false;    this.setData({num:"0",op:""})  }

3、其他功能实现

data:{  //  data中只放置初始数据  num:"1",  op:" "//记录运算符号 },  result:null,  isClear:false,//用来记录状态  numBtn:function(e){    var num =e.target.dataset.val//获取data-val中的值    //如果多次按0或者isClear为true,则将原来的数据清除,显示按的数字    if(this.data.num==='0'||this.isClear){      this.setData({num:num})//将获取的值给result      this.isClear=false    }else{        this.setData({num:this.data.num+num})    }  },   opBtn:function(e){    var op=this.data.op;//先记录当前的op    var num=Number(this.data.num);//获取当前的num数据    this.setData({op:e.target.dataset.val});//把按下的按钮给变量op    if(this.isClear){//因为上面操作中有如果按了运算符,则isclear为true,在这里为了避免多次按加都会起作用,再return      return    }    this.isClear=true;//当用户按了运算按钮,再按数字,则把原来的数字清空    if(this.result===null){      this.result=num;      return    }    if(op==="+"){      this.result=this.result+num      this.setData({num:this.result})//把加出来的结果为num    }else if(op==="-"){      this.result=this.result-num    }else if(op==="*"){      this.result=this.result*num    }else if(op==="/"){      this.result=this.result/num    }else if(op==="%"){      this.result=this.result%num    }    this.setData({num:this.result+""})//转为字符串类型   },  doBtn:function(e){    if(this.isClear){//表示上一个运算结束了,一开始就按.的话      this.setData({num:"0."});      this.isClear=false;      return    }    //如果多按了.    if(this.data.num.indexOf(".")>=0){      return    }    //正常数字后面按点    this.setData({num:this.data.num+"."})  },

感谢各位的阅读!关于“javascript如何实现计算器功能”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯