• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

微信小程序开发(2) 计算器

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

在这篇微信小程序开发教程中,我们将介绍如何使用微信小程序开发计算器功能。

本文主要分为两个部分,小程序主体部分及计算器业务页面部分

 

一、小程序主体部分

一个小程序主体部分由三个文件组成,必须放在项目的根目录,如下:

 

1. 小程序逻辑

App({
  onLaunch: function() { 
    // Do something initial when launch.
  },
  onShow: function() {
      // Do something when show.
  },
  onHide: function() {
      // Do something when hide.
  },
  globalData: \'I am global data\'
})

 

2. 小程序公共设置

{
  "pages": [
    "page/index/index"
  ],
  "window": {
    "navigationBarBackgroundColor": "#000",
    "backgroundColor": "#000",
    "navigationBarBackgroundColor": "#000"
  },
  "networkTimeout": {
    "request": 10000,
    "connectSocket": 10000,
    "uploadFile": 10000,
    "downloadFile": 10000
  },
  "debug": true
}

 

 

 

二、计算器页面部分

计算器页面主要由以下文件组成。

1. 计算器页面结构

页面结构分为2个主要部分:显示区和键盘区

其中键盘区又分功能键、数字键,及运算键,页面结构如下

<template name="calculator-key">
  <button hover-start-time="{{5}}" hover-stay-time="{{20}}" hover-class="calculator-key-hover" data-key="{{className}}" class="calculator-key {{className}}">{{display}}</button>
</template>

<view class="calculator">
  <view class="calculator-display">
    <view class="calculator-display-text">{{displayValue}}</view>
  </view>
  <view class="calculator-keypad">
    <view class="input-keys">
      <view class="function-keys" catchtap="onTapFunction">
        <template is="calculator-key" data="{{className: \'key-clear\', display: clearDisplay ? \'C\' : \'AC\'}}"/>
        <template is="calculator-key" data="{{className: \'key-sign\', display: \'±\'}}"/>
        <template is="calculator-key" data="{{className: \'key-percent\', display: \'%\'}}"/>
      </view>
      /*sdf*/
      <view class="digit-keys" catchtap="onTapDigit">
        <template is="calculator-key" data="{{className: \'key-0\', display: \'0\'}}"/>
        <template is="calculator-key" data="{{className: \'key-dot\', display: \'●\'}}"/>
        <template is="calculator-key" data="{{className: \'key-1\', display: \'1\'}}"/>
        <template is="calculator-key" data="{{className: \'key-2\', display: \'2\'}}"/>
        <template is="calculator-key" data="{{className: \'key-3\', display: \'3\'}}"/>
        <template is="calculator-key" data="{{className: \'key-4\', display: \'4\'}}"/>
        <template is="calculator-key" data="{{className: \'key-5\', display: \'5\'}}"/>
        <template is="calculator-key" data="{{className: \'key-6\', display: \'6\'}}"/>
        <template is="calculator-key" data="{{className: \'key-7\', display: \'7\'}}"/>
        <template is="calculator-key" data="{{className: \'key-8\', display: \'8\'}}"/>
        <template is="calculator-key" data="{{className: \'key-9\', display: \'9\'}}"/>
      </view>
    </view>
    <view class="operator-keys" catchtap="onTapOperator">
        <template is="calculator-key" data="{{className: \'key-divide\', display: \'÷\'}}"/>
        <template is="calculator-key" data="{{className: \'key-multiply\', display: \'×\'}}"/>
        <template is="calculator-key" data="{{className: \'key-subtract\', display: \'−\'}}"/>
        <template is="calculator-key" data="{{className: \'key-add\', display: \'+\'}}"/>
        <template is="calculator-key" data="{{className: \'key-equals\', display: \'=\'}}"/>
    </view>
  </view>
</view>

2. 计算器样式表

样式代码如下所示

@import "reset.wxss";

page {
  font: 100 14px \'Roboto\';
}

.calculator {
  width: 100%;
  height: 100vh;
  background: black;
  position: relative;
  box-shadow: 0px 0px 20px 0px #aaa;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

.calculator-display {
  background: #1c191c;
  flex: 1;
}

/*TODO:解决文本垂直居中问题*/
.calculator-display-text {
  padding: 0 30px;
  font-size: 6em;
  color: white;
  text-align: right;
}

.calculator-keypad {
  display: flex;
}

.calculator .function-keys {
  display: flex;
}

.calculator .digit-keys {
  background: #e0e0e7;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap-reverse;
}

.calculator-key-hover {
  box-shadow: inset 0px 0px 25vw 0px rgba(0,0,0,0.25);
}

.calculator-key {
  display: block;
  width: 25vw;
  height: 25vw;
  line-height: 25vw;
  border-top: 1px solid #777;
  border-right: 1px solid #666;
  text-align: center;
  box-sizing: border-box;
}

.calculator .function-keys .calculator-key {
  font-size: 2em;
}

.calculator .digit-keys .calculator-key {
  font-size: 2.25em;
}

.calculator .digit-keys .key-0 {
  width: 50vw;
  text-align: left;
  padding-left: 9vw;
}

.calculator .digit-keys .key-dot {
  padding-top: 1em;
  font-size: 0.75em;
}

.calculator .operator-keys .calculator-key {
  color: white;
  border-right: 0;
  font-size: 3em;
}

.calculator .function-keys {
  background: linear-gradient(to bottom, rgba(202,202,204,1) 0%, rgba(196,194,204,1) 100%);
}

.calculator .operator-keys {
  background:  linear-gradient(to bottom, rgba(252,156,23,1) 0%, rgba(247,126,27,1) 100%);
}

.input-keys {
  width: 75%;
}

.operator-keys {
  width: 25%;
}

3、 计算器页面逻辑处理

Page({
  data: {
    value: null, // 上次计算后的结果,null表示没有上次计算的结果
    displayValue: \'0\', // 显示数值
    operator: null, // 上次计算符号,null表示没有未完成的计算
    waitingForOperand: false // 前一按键是否为计算符号
  },

  onLoad: function(options) {
    this.calculatorOperations = {
      \'key-divide\': (prevValue, nextValue) => prevValue / nextValue,
      \'key-multiply\': (prevValue, nextValue) => prevValue * nextValue,
      \'key-add\': (prevValue, nextValue) => prevValue + nextValue,
      \'key-subtract\': (prevValue, nextValue) => prevValue - nextValue,
      \'key-equals\': (prevValue, nextValue) => nextValue
    }
  },
  
  /* AC操作,一下回到解放前 */
  clearAll() {
    this.setData({
      value: null,
      displayValue: \'0\',
      operator: null,
      waitingForOperand: false
    })
  },

  /* 仅清空当前显示的输入值 */
  clearDisplay() {
    this.setData({
      displayValue: \'0\'
    })
  },

  onTapFunction: function(event) {
    const key = event.target.dataset.key;

    switch(key) {
      case \'key-clear\':
        if (this.data.displayValue !== \'0\') {
          this.clearDisplay();
        } else {
          this.clearAll();
        }

        break;

      case \'key-sign\':
        var newValue = parseFloat(this.data.displayValue) * -1
        
        this.setData({
          displayValue: String(newValue)
        })

        break;

      case \'key-percent\':
        const fixedDigits = this.data.displayValue.replace(/^-?\d*\.?/, \'\')
        var newValue = parseFloat(this.data.displayValue) / 100
        
        this.setData({
          displayValue: String(newValue.toFixed(fixedDigits.length + 2))
        });

        break;
        
      default:
        break;
    }
  },

  onTapOperator: function(event) {
    const nextOperator = event.target.dataset.key;
    const inputValue = parseFloat(this.data.displayValue);
    
    if (this.data.value == null) {
      this.setData({
        value: inputValue
      });
    } else if (this.data.operator) {
      const currentValue = this.data.value || 0;
      const newValue = this.calculatorOperations[this.data.operator](currentValue, inputValue);

      this.setData({
        value: newValue,
        displayValue: String(newValue)
      });
    }
    
    this.setData({
      waitingForOperand: true,
      operator: nextOperator
    });
  },

  onTapDigit: function(event) {
    const key = event.target.dataset.key; // 根据data-key标记按键

    if(key == \'key-dot\') {
      // 按下点号
      if (!(/\./).test(this.data.displayValue)) {
        this.setData({
          displayValue: this.data.displayValue + \'.\',
          waitingForOperand: false
        })
      }
    } else {
      // 按下数字键
      const digit = key[key.length-1];

      if (this.data.waitingForOperand) {
        this.setData({
          displayValue: String(digit),
          waitingForOperand: false
        })
      } else {
        this.setData({
          displayValue: this.data.displayValue === \'0\' ? String(digit) : this.data.displayValue + digit
        })
      }
    }
  }
})

 

 

三、程序效果图

 

四、源代码下载

扫描下方二维码并关注公众账号,回复 “1236” 获取

源代码使用方法,请参考  微信小程序开发入门教程

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
微信小程序「官方示例代码」浅析【上】发布时间:2022-07-18
下一篇:
微信小程序——代码构成发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap