欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信小程序 简易计算器实现代码实例

程序员文章站 2022-05-14 16:46:34
这篇文章主要介绍了微信小程序 简易计算器实现代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 只能进行简单的运算...

这篇文章主要介绍了微信小程序 简易计算器实现代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

只能进行简单的运算

效果图如下:

微信小程序 简易计算器实现代码实例

cal.wxml

<view class="screen">{{result}}</view>
<view class="content"> 
 <view class="buttongroup">
  <button id="{{id1}}" bindtap="clickbutton" class="buttonitem color1" hover-class="shadow">清除</button>
  <button id="{{id2}}" bindtap="clickbutton" class="buttonitem color1" hover-class="shadow">回退</button>
  <button id="{{id3}}" bindtap="time" class="buttonitem color1" hover-class="shadow">
  <icon type="waiting" color="#66cc33"></icon>
  </button>
  <button id="{{id4}}" bindtap="clickbutton" class="buttonitem color2" hover-class="shadow1">÷</button>
 </view>

 <view class="buttongroup"> 
  <button id="{{id17}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow7">7</button>
  <button id="{{id18}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow8">8</button>
  <button id="{{id19}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow9">9</button>
  <button id="{{id5}}" bindtap="clickbutton" class="buttonitem color2" hover-class="shadow1">×</button>
 </view>

 <view class="buttongroup">
  <button id="{{id14}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow4">4</button>
  <button id="{{id15}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow5">5</button>
  <button id="{{id16}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow6">6</button>
  <button id="{{id6}}" bindtap="clickbutton" class="buttonitem color2" hover-class="shadow1">-</button>
 </view>

 <view class="buttongroup">
  <button id="{{id11}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow1">1</button>
  <button id="{{id12}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow2">2</button>
  <button id="{{id13}}" bindtap="clickbutton" class="buttonitem color3" hover-class="shadow3">3</button>
  <button id="{{id7}}" bindtap="clickbutton" class="buttonitem color2" hover-class="shadow1">+</button>
 </view>

 <view class="buttongroup">
  <button id="{{id10}}" bindtap="clickbutton" class="buttonitem1 color3" hover-class="shadow0">0</button>
  <button id="{{id8}}" bindtap="clickbutton" class="buttonitem1 color2" hover-class="shadow1">.</button>
  <button id="{{id9}}" bindtap="equal" class="buttonitem1 color2" hover-class="shadow1">=</button>
 </view>
</view>

cal.wxss

/* pages/cal/cal.wxss */
page{
 background: #000000;
}
.screen{
 position: fixed;
 color: #ffffff;
 font-size: 30px;
 bottom: 780rpx;
 text-align: right;
 width: 730rpx;
 word-wrap: break-word;
}
.content{
 position: fixed;
 bottom: 0;
}
.buttongroup{
 display: flex;
 flex-direction: row;
}
.buttonitem{
 text-align: center;
 line-height: 148rpx;
 width: 192rpx;
 border-radius: 0;
}
.buttonitem1{
 width: 255rpx;
 text-align: center;
 line-height: 148rpx;
 border-radius: 0;
}
icon{
 position: absolute;
 top: 30rpx;
 left: 67rpx;
}
.color1{
 background: #ccff99;
}
.color2{
 background: #ffff99;
}
.color3{
 background: rgb(167, 223, 241);
}
.shadow{
 background: #88e676;
}
.shadow0{
 background: rgb(149, 118, 243);
}
.shadow1{
 background: #ffcc66;
}
.shadow2{
 background: #99ff00;
}
.shadow3{
 background: #ff9999;
}
.shadow4{
 background: #00cc66;
}
.shadow5{
 background: #00ccff;
}
.shadow6{
 background: rgb(248, 80, 80);
}
.shadow7{
 background: #ffccff;
}
.shadow8{
 background: #cccccc;
}
.shadow9{
 background: #ccffff;
}

cal.js

// pages/cal/cal.js
page({
 data: {
  result:"0",
  id1:"clear",
  id2:"back",
  id3:"time",
  id4:"div",
  id5:"mul",
  id6:"sub",
  id7:"add",
  id8:"dot",
  id9:"eql",
  id10:"num_0",
  id11:"num_1",
  id12:"num_2",
  id13:"num_3",
  id14:"num_4",
  id15:"num_5",
  id16:"num_6",
  id17:"num_7",
  id18:"num_8",
  id19:"num_9",
  buttondot:false,
 },
 clickbutton: function (e) {
  console.log(e);
  var buttonval = e.target.id;
  var res = this.data.result;
  var newbuttondot=this.data.buttondot;
  var sign;
  if (buttonval >= "num_0" && buttonval <= "num_9") {
   var num=buttonval.split('_')[1];
   if (res == "0" || res.charat(res.length -(length-1)) == "=") {
    res = num;
   }
   else {
    res = res + num;
   }
  }
  else{
   if(buttonval=="dot")
   {
    if(!newbuttondot)
    {
     res = res + '.';
    }
   }
   else if(buttonval=="clear")
   {
    res='0';
   }
   else if(buttonval=="back")
   {
    var length=res.length;
    if(length>1)
    {
     res=res.substr(0,length-1);
    }
    else{
     res='0';
    }
   }
   else if (buttonval == "div" || buttonval == "mul" || buttonval == "sub" || buttonval == "add")
   {
    switch(buttonval){
     case "div":
      sign ='÷';
      break;
     case "mul":
      sign ='×';
      break;
     case "sub":
      sign='-';
      break;
     case "add":
      sign='+';
      break;
    }
    if(!isnan(res.charat(res.length-1)))
    {
     res=res+sign;
    }
   }
  }
  this.setdata({
   result: res,
   buttondot:newbuttondot,
  });
 },
 equal: function(e){
  var str=this.data.result;
  var item= '';
  var strarray = [];
  var temp=0;
  for(var i=0;i<=str.length;i++){
   var s=str.charat(i);
   if((s!='' && s>='0' && s<='9') || s=='.'){
    item=item+s;
   }
   else{
    strarray[temp]=item;
    temp++;
    strarray[temp]=s;
    temp++;
    item='';
   }
  }
  if(isnan(strarray[strarray.length-1]))
  {
   strarray.pop();
  }
  var num;
  var res=strarray[0]*1;
  for(var i=1;i<=strarray.length;i=i+2){
   num=strarray[i+1];
   switch(strarray[i]){
    case "-":
     res = res - num;
     break;
    case "+":
     res = res + num;
     break;
    case "×":
     res = res * num;
     break;
    case "÷":
    if(num!='0')
    {
     res = res / num;
    }
    else
    {
     res ='∞';
     break;
    } 
     break;
   }
  }
  this.setdata({
   result:'='+res,
  });
 },
 time:function(e){
  var util=require("../../utils/util.js");
  var time=util.formattime(new date());
  this.setdata({
   result:time
  });
 }

})

cal.json

{
 "navigationbarbackgroundcolor": "#ff9900",
 "navigationbartitletext": "en计算器",
 "usingcomponents": {}
}

其中有一些小错误,望大神指正!!!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。