今天按着自己的思路又重打了一遍

wxml没什么说的,就是分块起名,显示数字和结果的作为屏幕,数字键盘一行四块

<view class="onTop">
<view class="screen">{{screenData}}</view>
</view>
<!--键盘操作-->
<view class="onBottom">
<view class="Row">
<view class="item blue" bindtap='onTap' id="{{clear}}">C</view>
<view class="item blue" bindtap='onTap' id="{{del}}">←</view>
<view class="item blue" bindtap='history' id="{{history}}">history</view>
<view class="item blue" bindtap='onTap' id="{{add}}">+</view> </view>
<view class="Row">
<view class="item orange" bindtap='onTap' id="{{id9}}">9</view>
<view class="item orange" bindtap='onTap' id="{{id8}}">8</view>
<view class="item orange" bindtap='onTap' id="{{id7}}">7</view>
<view class="item blue" bindtap='onTap' id="{{minus}}">-</view> </view>
<view class="Row">
<view class="item orange" bindtap='onTap' id="{{id6}}">6</view>
<view class="item orange" bindtap='onTap' id="{{id5}}">5</view>
<view class="item orange" bindtap='onTap' id="{{id4}}">4</view>
<view class="item blue" bindtap='onTap' id="{{multiply}}">*</view> </view>
<view class="Row">
<view class="item orange" bindtap='onTap' id="{{id3}}">3</view>
<view class="item orange" bindtap='onTap' id="{{id2}}">2</view>
<view class="item orange" bindtap='onTap' id="{{id1}}">1</view>
<view class="item blue" bindtap='onTap' id="{{divided}}">/</view> </view>
<view class="Row">
<view class="item zero orange" bindtap='onTap' id="{{id0}}">0</view>
<view class="item orange" bindtap='onTap' id="{{dot}}">.</view>
<view class="item blue" bindtap='onTap' id="{{equal}}">=</view> </view>
</view>

wxss调调样式

有几个首次用的地方记录一下:

display:flex

 Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。设为Flex布局以后,子元素的floatclearvertical-align属性将失效。

它即可以应用于容器中,也可以应用于行内元素。

flex-direction

1 .box { 2 flex-direction: row | row-reverse | column | column-reverse; 3 }

属性可选值的范围为row(默认)沿水平主轴由左向右排列、row-reverse沿水平主轴由右向左排列、column沿垂直主轴右上到下和column-reverse。

align-items: center;align-items 属性定义flex子项在flex容器的当前行的侧轴(纵轴)方向上的对齐方式。

justify-content: center;justify-content 用于设置或检索弹性盒子元素在主轴(横轴)方向上的对齐方式。

然后是js

js分4种条件判断

首先获取输入的值,其次判断他的符号

1.如果输入的符号是删除,判断是否为0,反之,那就对字符串进行最后一位的删除,用substring截取到倒数第二位反映到前台显示,如果删没了就保持为0;同时在后台记录的数组中pop出最后一位;

 if(id==this.data.del){//删除的实现
var data=this.data.screenData;
if(data=="0"){
return ;
}
data=data.substring(0,data.length-1);//删除data数组最后一位,实现删除
if(data==""||data=="-")
{
data=0;
}
this.setData({"screenData":data});
this.data.arr.pop();

2.如果输入的符号是清零,那就简单粗暴的将前台显示设置为0;同时后台存储的数组清空;

else if(id==this.data.clear){//清屏
this.setData({"screenData":0});
this.data.arr.length=0;}

3如果输入的是加减乘除和数字的话判断符号不能连续输入,将输入的数字和符号连续的存入数组arr中,然后在前台显示

else{//+-*/和数字输入
if(this.data.operaSym[id]){
if(this.data.lastIsOperaSym||this.data.screenData=="0"){//禁止多输入符号
return;
}
}
var sd=this.data.screenData;
var data;
if(sd==0){
data=id;
}
else{
data=sd+id;
}
this.setData({"screenData":data});
this.data.arr.push(id);
if (this.data.operaSym[id]) {//判断是否输入符号
this.setData({ "lastIsOperaSym": true });
} else {
this.setData({ "lastIsOperaSym": false });
}
}
4输入的是等号,在等号中对数据进行处理,还没改对,result值搞不出来,再调试一下

心得:之前没看懂arr哪里传的值还以为是默认传进去的,还跑到大佬的源码底下问人家,丢人的想捂脸跑

微信小程序计算器模拟后续的更多相关文章

  1. 微信小程序计算器后后续

    改的眼睛都要瞎了,总算是知道问题出哪了 最后一段 在等号里面计算输入的数组,这个判断的主要操作是将输入的数据的数组进行数和符号的拆分然后再计算,把数按字符串输入数组,然后将数和符号进行拆分 ,最后通过 ...

  2. 微信小程序计算器Bug版=-=(笔记)

    微信小程序计算器BUG版本 无APPID的测试号登录,先在app.json中更改路径,以及修改头部信息. 首先一个输入框字段用{{screenData}} 功能可以退格,清屏,正负号,正常操作加减乘除 ...

  3. (一)微信小程序之模拟调用后台接口踩过的坑

    如下图标记的三个点 在调试过程中出现问题,特此记录. 1. 之前在浏览器测试接口习惯省略 http:// ,是因为浏览器默认有一个检测,在你输入的网址前面加http://,如果有就不加. 然而在微信小 ...

  4. wn-cli 像React组件开发一样来开发微信小程序

    项目地址:wn-cli wn-cli wn-cli 像React组件开发一样来开发微信小程序 名字由来:wn -> weapp native 取第一个字母 Install npm install ...

  5. 近期热门微信小程序demo源码下载汇总

    近期微信小程序demo源码下载汇总,乃小程序学习分析必备素材!点击标题即可下载: 即速应用首发!原创!电商商场Demo 优质微信小程序推荐 -秀人美女图 图片下载.滑动翻页 微信小程序 - 新词 GE ...

  6. 剖析简易计算器带你入门微信小程序开发

    写在前面,但是重点在后面 这是教程,也不是教程. 可以先看Demo的操作动图,看看是个什么玩意儿,GitHub地址(https://github.com/dunizb/wxapp-sCalc) 自从微 ...

  7. 获取 wx.getUserInfo 接口后续将不再出现授权弹窗,请注意升级(微信小程序开发)

    微信小程序开发时,Console 提示:获取 wx.getUserInfo 接口后续将不再出现授权弹窗,请注意升级 错误原因: 直接调用这个方法依旧可以获取用户信息, 但是如果你之前没有点击过那个授权 ...

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

    在这篇微信小程序开发教程中,我们将介绍如何使用微信小程序开发计算器功能. 本文主要分为两个部分,小程序主体部分及计算器业务页面部分 一.小程序主体部分 一个小程序主体部分由三个文件组成,必须放在项目的 ...

  9. 微信小程序-简易计算器

    代码地址如下:http://www.demodashi.com/demo/14210.html 一.前期准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.co ...

随机推荐

  1. One Technical Problem: Can one process load two different c libraries simutaneously, such as uclibc and glibc?

    For some special reasons, there is a possible case which need to load uclibc and glibc in one proces ...

  2. linux文件系统变为只读解决

    linux控制台显示文件系统变为只读,需输密码或者按ctrl+d结束 输入root密码后执行fsck -y /dev/sda1,fsck -y /dev/sda2和fsck -y /dev/sda3等 ...

  3. git本地仓库 push到远程仓库出现错误

    ! [rejected] master -> master (fetch first) error: failed to push some refs to hint: Updates were ...

  4. Hibernate 补充 ManyToOne、OneToMany、OneToOne的使用例

    1.前言      Hibernate 为程序员提供一种级联操作,在编写程序时,通过 Hibernate 的级联功能可以很方便的操作数据库的主从表的数据, 我们最常用的级联是级联保存和级联删除.   ...

  5. spring拦截器-过滤器的区别

    1.  理解 拦截器 :是在面向切面编程的时候,在你的 service 或者一个方法前调用一个方法,或者在方法后调用一个方法:比如动态代理就是拦截器的简单实现,在你调用方法前打印出字符串(或者做其它业 ...

  6. expect-调试模式的使用

    1.expect简介 Expect是一种TCL扩展性的语言,主要用于完成系统交互方面的功能,比如SSH.FTP等,这些程序都需要手工与它们进行互动,而使用Expect就可以模拟人手工互动的过程,是一种 ...

  7. 271A

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdbool.h& ...

  8. C#设计模式(8)——桥接模式(Bridge Pattern)(转)

    一.引言 这里以电视遥控器的一个例子来引出桥接模式解决的问题,首先,我们每个牌子的电视机都有一个遥控器,此时我们能想到的一个设计是——把遥控器做为一个抽象类,抽象类中提供遥控器的所有实现,其他具体电视 ...

  9. Servlet Analysis

    @WebServlet("/cdiservlet") //url映射 public class NewServlet extends HttpServlet { private M ...

  10. PHP----------file_get_content获取不到页面信息

    1.将网址在页面上打开可以正常访问,但是用file_get_content请求则访问不到.这个是因为对方挡住了非浏览器访问导致的.需要改下php配置,模拟浏览器访问. user_agent=" ...