参考部分资料,编写一个简单的计算器案例,虽然完成了正常需求,但是也有不满之处,待后续实力提升后再来补充,先把不足之处列出:
1:本来打算只要打开页面,计算器的输入框会显示一个默认为0的状态,但是在输入框加入默认显示为0的时候,选择数据输入时,该0会显示输入数字的前面,例如”0123“,由于能力有限,待后续实力提升再来补充完善!
2:目前只能实现鼠标控制选择按钮,待完善键盘录入功能。
3:乘法的那个符号在本来想改成”ד这个符号的,待后续完善。
附图片一张:
html部分:
<!DOCTYPE html> <html lang=\"en\"> <head> <meta charset=\"utf-8\"> <title>计算器</title> </head> <body onload=\"onLoad()\"> <div id=\"calculator\"> <div class=\"LOGO\"> <span class=\"name\">简单的计算器</span> <span class=\"verson\">@liumobai v1.0</span> </div> <div id=\"shuRu\"> <!--screen输入栏--> <div class=\"screen\"> <input type=\"text\" id=\"screenName\" name=\"screenName\" class=\"screen\" value=\"\" onfocus=\"jsq(this)\"> </div> </div> <div id=\"keys\"> <!-- operators and other keys --> <!--第一排--> <input type=\"button\" id=\"7\" onclick=\"jsq(this.id)\" value=\"7\" class=\"buttons\"> <input type=\"button\" id=\"8\" onclick=\"jsq(this.id)\" value=\"8\" class=\"buttons\"> <input type=\"button\" id=\"9\" onclick=\"jsq(this.id)\" value=\"9\" class=\"buttons\"> <input type=\"button\" id=\"Back\" onclick=\"tuiGe()\" value=\"Back\" class=\"buttons\"> <input type=\"button\" id=\"C\" onclick=\"clearNum()\" value=\"C\" class=\"buttons\" style=\"margin-right:0px\"> <!--第二排--> <input type=\"button\" id=\"4\" onclick=\"jsq(this.id)\" value=\"4\" class=\"buttons\"> <input type=\"button\" id=\"5\" onclick=\"jsq(this.id)\" value=\"5\" class=\"buttons\"> <input type=\"button\" id=\"6\" onclick=\"jsq(this.id)\" value=\"6\" class=\"buttons\"> <input type=\"button\" id=\"*\" onclick=\"jsq(this.id)\" value=\"*\" class=\"buttons\"> <input type=\"button\" id=\"/\" onclick=\"jsq(this.id)\" value=\"/\" class=\"buttons\" style=\"margin-right:0px\"> <!--第三排--> <input type=\"button\" id=\"1\" onclick=\"jsq(this.id)\" value=\"1\" class=\"buttons\"> <input type=\"button\" id=\"2\" onclick=\"jsq(this.id)\" value=\"2\" class=\"buttons\"> <input type=\"button\" id=\"3\" onclick=\"jsq(this.id)\" value=\"3\" class=\"buttons\"> <input type=\"button\" id=\"+\" onclick=\"jsq(this.id)\" value=\"+\" class=\"buttons\"> <input type=\"button\" id=\"-\" onclick=\"jsq(this.id)\" value=\"-\" class=\"buttons\" style=\"margin-right:0px\"> <!--第四排--> <input type=\"button\" id=\"0\" onclick=\"jsq(this.id)\" value=\"0\" class=\"buttons\"> <input type=\"button\" id=\"00\" onclick=\"jsq(this.id)\" value=\"00\" class=\"buttons\"> <input type=\"button\" id=\".\" onclick=\"jsq(this.id)\" value=\".\" class=\"buttons\"> <input type=\"button\" id=\"%\" onclick=\"jsq(this.id)\" value=\"%\" class=\"buttons\"> <input type=\"button\" id=\"eva\" onclick=\"eva()\" value=\"=\" class=\"buttons\" style=\"margin-right:0px\"> </div> <div class=\"footer\"> <span class=\"aside\">欢迎使用JavaScript计算器</span> <span class=\"link\"> <a href=\"#\" title=\"声明\" target=\"_blank\">反馈</a> </span> </div> </div> </body> </html>
JS部分:
<script> var num = 0; // 定义第一个输入的数据 function jsq(num) { //获取当前输入 document.getElementById(\'screenName\').value += document.getElementById(num).value; } function eva() { //计算输入结果 document.getElementById(\"screenName\").value = eval(document.getElementById(\"screenName\").value); } function clearNum() { //清0 document.getElementById(\"screenName\").value = null; document.getElementById(\"screenName\").focus(); } function tuiGe() { //退格 var arr = document.getElementById(\"screenName\"); arr.value = arr.value.substring(0, arr.value.length - 1); } function onLoad(){ //加载完毕后光标自动对应到输入框 document.getElementById(\"screenName\").focus(); } </script>
CSS部分:
/*Basic reset*/ *{ margin:0; padding:0; box-sizing: border-box; font: 14px Arial,sans-serif; } html{ height:100%; background-color:lightslategrey; } #calculator{ margin: 15px auto; width:330px; height:400px; border: 1px solid lightgray; background-color:darkgrey; padding:15px; } /*LOGO*/ .LOGO{ height:20px; } .LOGO .name{ float:left; line-height:30px; } .LOGO .verson{ float:right; line-height:30px; } /*screen*/ #shuRu{ margin-top:15px; } .screen{ margin-top:5px; width:300px; height:40px; text-align: right; padding-right:10px; font-size:20px; } #keys{ border:1px solid lightgray; height:223px; margin-top:25px; padding:8px; } #keys .last{ margin-right:0px; } .footer{ margin-top:20px; height:20px; } .footer .link{ float:right; } #keys .buttons{ float:left; width: 42px; height: 36px; text-align:center; background-color:lightgray; margin: 0 17px 20px 0; }
接下来再给大家分享一则实例
<html> <head> <title>Untitled</title> <style type=\"text/css\"> input[type=button] { width:25px; height:25px; } </style> <script type=\"text/javascript\"> var result=0; var point=false; //判断是小数点前还是后 var multiple=0.1; //初始化小数点后的倍率 var sort=0; //标记加减乘除 var temp=0; //记录上一轮结果 function onbutton0() //数字按钮动作 { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+0; //小数点前的处理 else //小数点后的处理 { result=result+multiple*0; multiple=multiple*0.1; } name.value=String(result); } function onbutton1() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+1; else { result=result+multiple*1; multiple=multiple*0.1; } name.value=String(result); } function onbutton2() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+2; else { result=result+multiple*2; multiple=multiple*0.1; } name.value=String(result); } function onbutton3() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+3; else { result=result+multiple*3; multiple=multiple*0.1; } name.value=String(result); } function onbutton4() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+4; else { result=result+multiple*4; multiple=multiple*0.1; } name.value=String(result); } function onbutton5() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+5; else { result=result+multiple*5; multiple=multiple*0.1; } name.value=String(result); } function onbutton6() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+6; else { result=result+multiple*6; multiple=multiple*0.1; } name.value=String(result); } function onbutton7() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+7; else { result=result+multiple*7; multiple=multiple*0.1; } name.value=String(result); } function onbutton8() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+8; else { result=result+multiple*8; multiple=multiple*0.1; } name.value=String(result); } function onbutton9() { var name=document.getElementByIdx_x(\"show\"); if(!point) result=10*result+9; else { result=result+multiple*9; multiple=multiple*0.1; } name.value=String(result); } function onbutton_point() //小数点按钮 { var name=document.getElementByIdx_x(\"show\"); point=true; name.value=String(result)+\".\"; } function onbutton_back() //退格按钮 { var name=document.getElementByIdx_x(\"show\"); var temp=name.value; name.value=\"\"; for(var i=0;i<temp.length-1;i++) name.value+=temp[i]; } function onbutton_plus() { var name=document.getElementByIdx_x(\"show\"); point=false; multiple=0.1; switch (sort) //遇到下一个操作符时判断上一个操作符是什么,并进行上一个操作符的计算 { //eg:1+2+3= 遇到第二个+时判断前一个符号,发现是+则进行+运算,得到3赋给result case 1:result=result+temp; break; case 2:result=temp-result; break; case 3:result=temp*result; break; case 4:result=temp/result; break; } sort=1; temp=result; result=0; name.value=\"0\"; } function onbutton_minus() { var name=document.getElementByIdx_x(\"show\"); point=false; multiple=0.1; switch (sort) { case 1:result=result+temp; break; case 2:result=temp-result; break; case 3:result=temp*result; break; case 4:result=temp/result; break; } sort=2; temp=result; result=0; name.value=\"0\"; } function onbutton_mult() { var name=document.getElementByIdx_x(\"show\"); point=false; multiple=0.1; switch (sort) { case 1:result=result+temp; break; case 2:result=temp-result; break; case 3:result=temp*result; break; case 4:result=temp/result; break; } sort=3; temp=result; result=0; name.value=\"0\"; } function onbutton_div() { var name=document.getElementByIdx_x(\"show\"); point=false; multiple=0.1; switch (sort) { case 1:result=result+temp; break; case 2:result=temp-result; break; case 3:result=temp*result; break; case 4:result=temp/result; break; } sort=4; temp=result; result=0; name.value=\"0\"; } function onbutton_equal() { var name=document.getElementByIdx_x(\"show\"); point=false; //重置 multiple=0.1; //重置 switch (sort) { case 1:result=result+temp; break; case 2:result=temp-result; break; case 3:result=temp*result; break; case 4:result=temp/result; break; } sort=0; //重置 temp=result; result=0; name.value=String(temp); } function onbutton_clear() //重置为初始状态 { result=0; point=false; multiple=0.1; //初始化小数点后的倍率 sort=0; //标记加减乘除 temp=0; //记录上一轮结果 var name=document.getElementByIdx_x(\"show\"); name.value=\"0\"; } </script> </head> <body> <table align=\"center\"> <tr> <td colspan=\"5\"><input type=\"text\" value=\"0\" id=\"show\"></td> </tr> <tr> <td><input type=\"button\" value=\"7\" onclick=\"onbutton7();\"></td> <td><input type=\"button\" value=\"8\" onclick=\"onbutton8();\"></td> <td><input type=\"button\" value=\"9\" onclick=\"onbutton9();\"></td> <td><input type=\"button\" value=\"/\" onclick=\"onbutton_div();\"></td> <td><input type=\"button\" value=\"<\" onclick=\"onbutton_back();\"></td> </tr> <tr> <td><input type=\"button\" value=\"4\" onclick=\"onbutton4();\"></td> <td><input type=\"button\" value=\"5\" onclick=\"onbutton5();\"></td> <td><input type=\"button\" value=\"6\" onclick=\"onbutton6();\"></td> <td><input type=\"button\" value=\"*\" onclick=\"onbutton_mult();\"></td> <td><input type=\"button\" value=\"C\" onclick=\"onbutton_clear();\"></td> </tr> <tr> <td><input type=\"button\" value=\"1\" onclick=\"onbutton1();\"></td> <td><input type=\"button\" value=\"2\" onclick=\"onbutton2();\"></td> <td><input type=\"button\" value=\"3\" onclick=\"onbutton3();\"></td> <td><input type=\"button\" value=\"-\" onclick=\"onbutton_minus();\"></td> <td rowspan=\"2\"><input type=\"button\" value=\"=\" style=\"width:25px;height:57px;\" onclick=\"onbutton_equal();\"></td> </tr> <tr> <td colspan=\"2\"><input type=\"button\" value=\"0\" style=\"width:57px;height:25px;\" onclick=\"onbutton0();\"></td> <td><input type=\"button\" value=\".\" onclick=\"onbutton_point();\"></td> <td><input type=\"button\" value=\"+\" onclick=\"onbutton_plus();\"></td> </tr> </table> </body> </html>
本文地址:https://www.stayed.cn/item/7768
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我