纯HTML+CSS+JS编写的计算器应用

简介:

一道笔试题

之前偶然看到一个公司的笔试题,题目如下:

用HTML5、CSS3、JavaScript,做一个网页,实现如下图形式计算器

具体要求:

  1. 有且只有一个文件:index.html。不允许再有其他文件,不允许再有单独的CSS、JS、PNG、JPG文件。
  2. 运行环境为 Google Chrome。
  3. 必须支持标准的四则运算。例如:1+2*3=7。
  4. 请在收到邮件的48小时内独立完成本测试,并回复本邮件。

一道笔试题引发的一个练手项目

花了一点时间写好的第一版,符合了笔试题的要求。后来左看右看觉得还可以改进做的更好,于是给它不断的改进,加新功能等,这样下来没完没了,利用业余时间一点一点的写,从刚开始的网页版,到后来做响应式的移动版,再到现在的移动App,短短续续大概写了3个月吧。

项目地址

最终版的计算器,项目地址和预览图片在 GitHub:https://github.com/dunizb/sCalc。

功能说明

最终版的功能如下:

  1. 界面布局采用CSS3 的 Flex box布局
  2. 内置两套主题可切换
  3. 计算历史记录显示
  4. 左滑右滑可以切换单手模式(App)
  5. 当输入手机号码后长按等于号可以拨打手机号码(App)
  6. 版本更新检查(App)

界面布局

由于这个项目只是练手,所以采用了HTML5个CSS3技术,也不打算兼容IE等低版本浏览器,所以直接使用CSS3提供的Flexbox布局方式。并且使用rem单位来进行自动计算尺寸。

计算计算历史记录显示功能,使用HTML5提供的本地存储功能之Local Storage,为了方便使用Local Storage,对它进行了简单的封装(见js/common.js文件)使之key值按一定规律生产,方便管理。

key由appName+id组成,id是自动增长不重复的,可以按id和appName删除一条记录,输入*则全部删除。

打包APP

移动Web版计算器写完后,又想把他做成APP在手机上运行,由于本人没用过混合APP诸如ionic之类的框架,所以参考了一下,选择了Hbuild来进行开发和APP的打包,非常方便。(HBuild).

单手模式

左滑右滑可以切换单手模式,这就需要移动端的touch事件了,使用如下代码判断是左滑还是右滑:


 
 
  1. /** 单手模式 */ 
  2.  
  3. function singleModel(){ 
  4.  
  5.     var calc = document.getElementById("calc"); 
  6.  
  7.     var startX = 0,moveX = 0,distanceX = 0; 
  8.  
  9.     var distance = 100;   
  10.  
  11.     var width = calc.offsetWidth; 
  12.  
  13.     //滑动事件 
  14.  
  15.     calc.addEventListener("touchstart",function(e){ 
  16.  
  17.         startX = e.touches[0].clientX; 
  18.  
  19.     }); 
  20.  
  21.     calc.addEventListener("touchmove",function(e){ 
  22.  
  23.         moveX = e.touches[0].clientX; 
  24.  
  25.         distanceX = moveX - startX; 
  26.  
  27.         isMove = true
  28.  
  29.     }); 
  30.  
  31.     window.addEventListener("touchend",function(e){ 
  32.  
  33.         if(Math.abs(distanceX) > width/3 && isMove){ 
  34.  
  35.             if( distanceX > 0 ){ 
  36.  
  37.                 positionFun("right");        //右滑 
  38.  
  39.             }else
  40.  
  41.                 positionFun("left");          //左滑 
  42.  
  43.             } 
  44.  
  45.         } 
  46.  
  47.         startY = moveY = 0; 
  48.  
  49.         isMove = false
  50.  
  51.     });   
  52.  
  53. }  

如果是左滑,就position:absolut;left:0,bottom:0,再把最外层DIV缩小到80%,这样就实现了左滑计算器缩小移动到左下角。右滑道理一样。

电话拨打功能

当输入手机号码后长按等于号可以拨打手机号码。这个功能没什么神奇,在移动Web上会对那些看起来像是电话号码的数字处理为电话链接,比如:

  • 7位数字,形如:1234567
  • 带括号及加号的数字,形如:(+86)123456789
  • 双连接线的数字,形如:00-00-00111
  • 11位数字,形如:13800138000

可能还有其他类型的数字也会被识别。我们可以通过如下的meta来开启电话号码的自动识别:


 
 
  1. <meta name="format-detection" content="telephone=yes" /> 

开启电话功能


 
 
  1. <a href="tel:123456">123456</a> 

开启短信功能:


 
 
  1. <a href="sms:123456">123456</a> 

但是,在Android系统上,只能调用系统的拨号界面,在iOS上则能调过这一步直接把电话拨打出去。

版本更新检查

在关于页面,有一个版本更新检查按钮,就能检查是否有新版本,这个功能的原理是发送一个JSOPN请求去检查服务器上的JSON文件,比对版本号,如果服务器上的版本比APP的版本高则会提示有新版本可以下载。

客户端JavaScript代码:


 
 
  1. function updateApp(){ 
  2.  
  3.     //检查新版本 
  4.  
  5.     var updateApp = document.getElementById("updateApp"); 
  6.  
  7.     updateApp.onclick = function(){ 
  8.  
  9.         var _this = this; 
  10.  
  11.         $.ajax({ 
  12.  
  13.             type:'get'
  14.  
  15.             url:'http://duni.sinaapp.com/demo/app.php?jsoncallback=?'
  16.  
  17.             dataType:'jsonp'
  18.  
  19.             beforeSend : function(){ 
  20.  
  21.                 _this.innerHTML = "<i class='iconfont updateAppIcon updateAppIconRotate'></i> 正在检查新版本..."
  22.  
  23.             }, 
  24.  
  25.             success:function(data){ 
  26.  
  27.                 var newVer = data[0].version; 
  28.  
  29.                 if(newVer > appConfig.version){ 
  30.  
  31.                     var log = data[0].log; 
  32.  
  33.                     var downloadUrl = data[0].downloadUrl; 
  34.  
  35.                     if(confirm("检查到新版本【"+newVer+"】,是否立即下载?\n 更新日志:\n " + log)){ 
  36.  
  37.                         var a = document.getElementById("telPhone"); 
  38.  
  39.                         a.href = downloadUrl; 
  40.  
  41.                         a.target = "_blank"
  42.  
  43.                         a.click(); 
  44.  
  45.                     } 
  46.  
  47.                 }else
  48.  
  49.                     alert("你很潮哦,当前已经是最新版本!"); 
  50.  
  51.                 } 
  52.  
  53.                 _this.innerHTML = "<i class='iconfont updateAppIcon'></i> 检查新版本"
  54.  
  55.             }, 
  56.  
  57.             error:function(msg){ 
  58.  
  59.                 _this.innerHTML = "<i class='iconfont updateAppIcon'></i> 检查新版本"
  60.  
  61.                 alert("检查失败:"+msg.message); 
  62.  
  63.             } 
  64.  
  65.         }); 
  66.  
  67.     } 
  68.  

服务端JSON:


 
 
  1.  
  2.     { 
  3.  
  4.         "version":"3.1.0"
  5.  
  6.         "downloadUrl":"http://dunizb.b0.upaiyun.com/demo/app/myCalc-3.1.0.apk"
  7.  
  8.         "hashCode":"20160812224616"
  9.  
  10.         "log":"1.新增切换主题功能 \n 2.新增单手切换模式功能 \n 3.调整UI " 
  11.  
  12.     } 
  13.  

下个版本计划

当前3.1.0版本还存在一些问题:

  1. 由于JS本身存在计算浮点数精度丢失问题,所以这个问题在项目中同意存在,需要自己去处理这个问题
  2. 由于使用了第三方的天气接口,用了jquery.Ajax方法,所以违背了使用纯原生写的初衷。

所以下个版本的开发计划为:

  1. 解决浮点数计算精度问题
  2. 把获取天气信息的jquery.Ajax方法替换为原生JavaScript代码,自己封装JSONP请求函数
  3. 使用面向对象方式重构APP 
作者:佚名
来源:51CTO
相关文章
|
11月前
|
存储 前端开发 JavaScript
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
|
人工智能 程序员 UED
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
814 21
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
前端开发 JavaScript
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
664 14
【02】v1.0.1更新增加倒计时完成后的放烟花页面-优化播放器-优化结构目录-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
前端开发
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
1088 1
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
css3 svg制作404页面动画效果HTML源码
css3 svg制作404页面动画效果HTML源码
294 34
|
前端开发
“弘五四,耀青春”程序创意获奖作品【html+css】
本作品以“青春筑梦,共创未来”为主题,采用动态龙元素展现青春活力与创新精神。页面设计简洁明快,色彩协调,突显年轻人积极向上的风貌。作品内容包括获奖截图、名字《时代扬新帆》及源代码分享。特别说明:禁止用于商业活动,可用于比赛和作业等开源场景。最后,作者表达了对五四精神的致敬与传承,强调了青春活力和创造力的重要性,并感谢评委和支持者。 **获奖感言摘录:** “获得这个奖项,对我们团队来说,既是认可也是激励。我们将继续努力,不断优化产品,为用户带来更好的体验,为社会贡献更多价值。”
316 2
html+js+css实现的建筑方块立体数字时钟源码
html+js+css实现的建筑方块立体数字时钟源码
631 33
|
前端开发 JavaScript 搜索推荐
打造个人博客网站:从零开始的HTML和CSS之旅
【9月更文挑战第32天】在这个数字化的时代,拥有一个个人博客不仅是展示自我的平台,也是技术交流的桥梁。本文将引导初学者理解并实现一个简单的个人博客网站的搭建,涵盖HTML的基础结构、CSS样式的美化技巧以及如何将两者结合来制作一个完整的网页。通过这篇文章,你将学会如何从零开始构建自己的网络空间,并在互联网世界留下你的足迹。
一个好看的小时钟html+js+css源码
一个好看的小时钟html+js+css源码
278 24