微信小程序如何实现简单的计算器
发表于:2025-11-15 作者:千家信息网编辑
千家信息网最后更新 2025年11月15日,今天小编给大家分享一下微信小程序如何实现简单的计算器的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起
千家信息网最后更新 2025年11月15日微信小程序如何实现简单的计算器
今天小编给大家分享一下微信小程序如何实现简单的计算器的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
运行截图
计算器对于界面美观的要求并不高,只是一些view以及button控件的组合,所以并不需要在界面上费很多功夫。重要的是逻辑层,之所以选择计算器作为上手的第一个项目,因为计算器的逻辑可简可繁,完全可以适应新手对小程序的掌握程度。
主要代码
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, is_time:false }, clickButton: function (e) { console.log(e); var buttonVal = e.target.id; var res = this.data.result; if(this.data.is_time==true){ res=0 } var newbuttonDot=this.data.buttonDot; var sign; if (buttonVal >= "num_0" && buttonVal <= "num_9") { var num=buttonVal.split("_")[1]; if (res == "0" || ((res.length-0) -(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") { if(res.length){} else{ res=JSON.stringify(res) } var is_sign=res.substr(res.length-1,res.length) if(is_sign=="+"||is_sign=="-"||is_sign=="×"||is_sign=="÷"){ res=res.substr(0,res.length-1); } switch(buttonVal){ case "div": sign ="÷"; break; case "mul": sign ="×"; break; case "sub": sign="-"; break; case "add": sign="+"; break; } if(!isNaN(res.length)) { res.length-1; res=res+sign; } } } this.setData({ is_time:false, 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-0)- (num-0); break; case "+": res = (res-0) + (num-0); break; case "×": res = (res-0)* (num-0); break; case "÷": if(num!="0") { res = (res-0)/ (num-0); } 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, is_time:true }); }})wxml
简单计算器 {{result}}
wxss:
/**index.wxss**/page{ background: #f5f5f5; } .project_name{ position:absolute; top:25px; width:100%; text-align: center; font-size: 30px; } .screen_content{ position: fixed; color: #1b1717; background: #fff; font-size: 40px; bottom: 390px; text-align: right; height:100px; width: 100%; word-wrap: break-word; border-top:1px solid #a8a8a8; border-bottom:1px solid #a8a8a8; } .screen{ position: absolute; font-size: 40px; text-align: right; bottom:0px; width: 96%; left:2%; word-wrap: break-word; } .content{ position: fixed; bottom: 0; } .buttonGroup{ display: flex; flex-direction: row; } .buttonitem{ text-align: center; line-height: 120rpx; width: 25%; border-radius: 0; } .buttonitem1{ width: 192rpx; text-align: center; line-height: 120rpx; border-radius: 0; } icon{ position: absolute; top: 20%; left: 67rpx; } .color{ background: #fff; } .equal{ width: 380rpx; text-align: center; line-height: 120rpx; border-radius: 0; background: #fff; } .shadow{ background: #e9ebe9; }以上就是"微信小程序如何实现简单的计算器"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
计算器
知识
篇文章
程序
逻辑
内容
界面
不同
很大
重要
美观
之所以
代码
功夫
只是
大部分
就是
截图
控件
新手
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
只能检索国外学位论文的数据库
从国防建设角度谈网络安全
知网第三方软件开发
做好网络安全工作政策依据
vue可以连数据库吗
计算机网络技术可以分几条主线
三级网络技术 考纲
钉钉软件开发用户需求说明书
虎符网络安全赛
导航无法连接到服务器
王者荣耀新开服务器
网络安全儿童画文案
谷安网络安全工程师
服务器越高越好还是越低好
阴阳师应用宝服务器能买藏宝阁么
牢记十大网络安全金句
将表文件添加到数据库中
数据服务器备案
大冶服务优质的计算机软件开发
如何使用联合国商品数据库
银川办公软件开发报价多少
认真作好网络安全工作
wifi 认证服务器
阿里云服务器安全说明书
iptv涉及的网络技术
黄岛区商城软件开发解决方案
上传数据库空间
做好网络技术支撑
淘宝铺货软件开发
重庆复腾网络技术有限公司