javascript实现计算器功能详解流程

作者:凉沫love 时间:2024-04-23 09:27:00 

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;/*里面的大view排列为垂直*/
 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+"."})
 },

来源:https://blog.csdn.net/qq_50582468/article/details/121064756

标签:javascript,计算器
0
投稿

猜你喜欢

  • 盘点十个超级好用的高级Python脚本

    2023-12-04 23:41:27
  • 在Python的Flask框架中构建Web表单的教程

    2023-10-04 06:03:12
  • 架构师说比起404我们更怕200错误

    2022-11-02 20:40:43
  • MySQL 缓存 Query Cache

    2010-03-13 17:06:00
  • 43个应当避免的Web设计错误

    2007-09-30 12:57:00
  • Python+selenium实现趣头条的视频自动上传与发布

    2022-03-23 10:27:43
  • Pandas 稀疏数据结构的实现

    2022-01-29 15:08:32
  • 基于webstorm卡顿问题的2种解决方法

    2023-02-23 09:03:17
  • 基于python实现把json数据转换成Excel表格

    2021-02-20 05:22:04
  • python实现自动解数独小程序

    2023-03-28 12:15:19
  • SQL存储过程介绍

    2008-02-13 18:52:00
  • Jaspersoft Studio添加mysql数据库配置步骤

    2024-01-17 01:13:26
  • 批标准化层 tf.keras.layers.Batchnormalization()解析

    2023-06-18 23:35:17
  • sql 常用技巧整理

    2011-11-03 17:10:14
  • python基于搜索引擎实现文章查重功能

    2022-01-21 19:25:50
  • 在nginx中配置pathinfo模式支持thinkphp的URL重写

    2024-05-03 15:50:48
  • python strip()函数 介绍

    2023-06-15 11:59:47
  • Python图像处理库crop()函数 thumbnail方法使用详解

    2022-12-26 05:57:46
  • sqlserver 使用SSMS运行sql脚本的六种方法

    2024-01-15 14:51:11
  • PHP异常Parse error: syntax error, unexpected T_VAR错误解决方法

    2023-11-16 13:00:48
  • asp之家 网络编程 m.aspxhome.com