
jQuery简易灰色的手机网页计算器,采用逆波兰表达式计算器代码。
[声明] 墨鱼部落格所有资源为用户免费分享产生,若发现您的权利被侵害,请点击后方链接查看并联系我们,我们尽快处理。免责声明|侵权处理流程
使用方法:
1、head引入css文件
<style>
* {
margin: 0;
padding: 0;
-webkit-tap-highlight-color: transparent;
}
html, body {
height: 100%;
overflow: hidden;
}
.kiner-calc-container {
width: 100%;
margin: 0 auto;
border-left: 1px solid #e6e6e6;
border-top: 1px solid #e6e6e6;
overflow: hidden;
box-sizing: border-box;
display: flex;
flex-flow: column;
height: 100%;
zoom: 1;
max-width: 750px;
}
.result-panel {
flex: 1;
background: #f0f0f0;
box-sizing: border-box;
border: 5px #f2f3f7 solid;
text-align: right;
font-size: 56px;
color: #999;
box-shadow: inset 0 0 5px #aaa;
position: relative;
overflow: hidden;
}
.result-panel .data {
display: inline-block;
transform-origin: right center;
transition: all 300ms;
position: absolute;
right: 0;
top: 50%;
transform: translateY(-50%) scale(1);
padding-right: 10px;
word-break: keep-all;
height: fit-content;
}
.calc-container {
width: 100%;
display: flex;
flex-flow: column;
flex: 5;
}
.calc-container .row {
display: flex;
flex: 1;
border-top: 1px solid #e6e6e6;
justify-content: center;
box-sizing: border-box;
}
.row .key {
flex: 1;
text-align: center;
border-right: 1px solid #e6e6e6;
background: radial-gradient(#dddddd, #f2f3f7);
cursor: pointer;
font-size: 32px;
color: #333333;
user-select: none;
box-sizing: border-box;
transition: 100ms;
}
.row .key:before {
content: "";
display: inline-block;
vertical-align: middle;
height: 100%;
}
.row .key span {
display: inline-block;
vertical-align: middle;
}
.row .key.active {
transform: scale(.9);
box-shadow: 0 0 5px #333;
}
.row .special {
background: radial-gradient(orangered, #cf3800);
color: #FFFFFF;
}
</style>
2、body引入HTML代码
<div class="kiner-calc-container">
<div class="result-panel">
<span class="data"></span>
</div>
<div class="calc-container">
<div class="row">
<div class="key" data-key="("><span>(</span></div>
<div class="key" data-key=")"><span>)</span></div>
<div class="key" data-key="delAll"><span>CE</span></div>
<div class="key" data-key="/"><span>÷</span></div>
</div>
<div class="row">
<div class="key" data-key="7"><span>7</span></div>
<div class="key" data-key="8"><span>8</span></div>
<div class="key" data-key="9"><span>9</span></div>
<div class="key" data-key="*"><span>×</span></div>
</div>
<div class="row">
<div class="key" data-key="4"><span>4</span></div>
<div class="key" data-key="5"><span>5</span></div>
<div class="key" data-key="6"><span>6</span></div>
<div class="key" data-key="-"><span>-</span></div>
</div>
<div class="row">
<div class="key" data-key="1"><span>1</span></div>
<div class="key" data-key="2"><span>2</span></div>
<div class="key" data-key="3"><span>3</span></div>
<div class="key" data-key="+"><span>+</span></div>
</div>
<div class="row">
<div class="key" data-key="."><span>.</span></div>
<div class="key" data-key="0"><span>0</span></div>
<div class="key" data-key="del"><span>del</span></div>
<div class="key special" data-key="eq"><span>=</span></div>
</div>
</div>
</div>
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/kiner-calc.js"></script>
<script type="text/javascript">
// 完美解决 ios10 及以上 Safari 无法禁止缩放的问题
window.onload = function () {
// 阻止双击放大
var lastTouchEnd = 0;
document.addEventListener('touchstart', function (event) {
if (event.touches.length > 1) {
event.preventDefault();
}
});
document.addEventListener('touchend', function (event) {
var now = (new Date()).getTime();
if (now - lastTouchEnd <= 300) {
event.preventDefault();
}
lastTouchEnd = now;
}, false);
// 阻止双指放大
document.addEventListener('gesturestart', function (event) {
event.preventDefault();
});
}
var kinerCalc = new KinerCalc();
var resultPanel = $('.result-panel .data');
function calcFontSize(panelWidth, dataWidth) {
var rate = 1;
if (panelWidth < dataWidth) {
rate = panelWidth / (dataWidth + 40);
console.log(rate);
return rate;
} else {
return rate;
}
}
var isMobile = "ontouchend" in document ? true : false;
$('.calc-container').on(isMobile?'touchend':'click', '.key', function () {
var key = $(this).data('key');
var val = resultPanel.text();
$(this).addClass('active');
var _this = this;
setTimeout(function () {
$(_this).removeClass('active');
}, 100);
if (["+", "-", "*", "/"].indexOf(key) >= 0 && ["+", "-", "*", "/"].indexOf(val[val.length - 1]) >= 0) {
return false;
}
if (key === "eq") {
var txt = resultPanel.text();
if (txt.length === 0) {
return false;
}
var res = kinerCalc.calc(txt);
resultPanel.text(res);
} else if (key === "del") {
resultPanel.text(val.substring(0, val.length - 1));
} else if (key === "delAll") {
resultPanel.text('');
} else if (key === "(") {
if (["(", ")"].indexOf(val[val.length - 1]) >= 0) {
return false;
}
resultPanel.append(key);
} else if (key === ")") {
if (["(", ")"].indexOf(val[val.length - 1]) >= 0) {
return false;
}
resultPanel.append(key)
} else {
resultPanel.append(key);
}
resultPanel.css({
transform: 'translateY(-50%) scale(' + calcFontSize($('.result-panel').width(), resultPanel.width()) + ')'
});
});
</script>
文件目录
本资源来自:代码 » 其他特效 » 简易的移动端计算器代码
注:此资源非帝国CMS模板/特效/源码,需要帝国CMS整站模板源码的小伙伴,请移步 帝国CMS模板,感谢支持!
js个性打字动画个人简历代码
« 上一篇 2019年03月29日
js在线unicode编码与解码特效
下一篇 » 2019年03月28日
1、如非特殊说明,本站对本文提供的代码或者素材不拥有任何权利,其版权归原著者拥有。
2、以上提供的代码或者素材均为作者提供和网友推荐收集整理而来,仅供学习和研究使用。
3、如有侵犯你版权的,请来信(邮箱:48444431@qq.com)指出,核实后,本站将立即改正。
4、如有链接无法下载、失效或广告,请点击下面的报错或者联系墨鱼处理!
5、以上资源售价只是赞助,不代表代码或者素材本身价格。收取费用仅维持本站的服务器开销!
6、如无特殊说明,如:织梦或者帝国等开源CMS核心模板,那么默认提供的只是HTML模板!
7、所有代码素材效果均为演示打包,最终效果请参考演示效果,本站不提供任何技术支持和服务。
8、代码素材均为虚拟物品,演示和描述无错的情况下,无法进行退换服务。
2、以上提供的代码或者素材均为作者提供和网友推荐收集整理而来,仅供学习和研究使用。
3、如有侵犯你版权的,请来信(邮箱:48444431@qq.com)指出,核实后,本站将立即改正。
4、如有链接无法下载、失效或广告,请点击下面的报错或者联系墨鱼处理!
5、以上资源售价只是赞助,不代表代码或者素材本身价格。收取费用仅维持本站的服务器开销!
6、如无特殊说明,如:织梦或者帝国等开源CMS核心模板,那么默认提供的只是HTML模板!
7、所有代码素材效果均为演示打包,最终效果请参考演示效果,本站不提供任何技术支持和服务。
8、代码素材均为虚拟物品,演示和描述无错的情况下,无法进行退换服务。

