文档章节

简易网页计算器

Lee12
 Lee12
发布于 2017/08/05 13:35
字数 314
阅读 0
收藏 0

简易网页计算器,实现简单的"+-*/"的计算结果,写的比较繁琐,不喜勿喷

最终效果

css 样式

* {
                margin: 0;
                padding: 0;
            }
            
            .container {
                width: 500px;
                margin: 0 auto;
                border: 1px solid #000;
                font-size: 32px;
                background-color: black;
            }
            
            input {
                display: inline-block;
                width: 99%;
                height: 80px;
                margin: 3px auto;
            }

内容部分

<div class="container">
            <table width="100%" style="text-align: center;">
                <tr>
                    <td colspan="3"><input type="text" id="screen" value="0" disabled="disabled" style="text-align: right;"></td>
                    <td><input type="button" value="清除" id="clear"></td>
                </tr>
                <script type="text/javascript">
                    var btnStr = ["789+", "456-", "123*", "0.=/"],
                        point = 0;
                    var html = "";
                    for (var i = 0; i < btnStr.length; i++) {
                    console.log(btnStr[i]);
                        html += "<tr>"
                        for (var j = 0; j < btnStr[i].length; j++) {
                            html += "<td><input  class=btn type='button' value='";
                            html += btnStr[i][j];
                            html += "'/></td>";
                        }
                        html += "</tr>";
                    }
                    document.write(html);
                </script>
            </table>
        </div>
        <script type="text/javascript">
            var screen = document.getElementById("screen");
            var isNew = true;
            var result = 0; /*计算结果*/
            var preOperator = "+"; /*前一次点击的运算符*/
            document.body.onload = function() {
                var btns = document.getElementsByClassName("btn");
                for (var i in btns) {
                    btns[i].onclick = function(e) {
                        if ("0123456789.".indexOf(this.value) >= 0) {//输入数字
                            if (isNew == true) {
                                if(preOperator=="="){
                                    result=0;
                                    preOperator="+";
                                }
                                if (screen.value == "0" && this.value == "0") return;
                                if (this.value == ".")
                                    screen.value = "0" + this.value;
                                else
                                    screen.value = this.value;
                                    isNew = false;
                                if (screen.value != 0)
                                    isNew = false;
                            } else {
                                if (screen.value.indexOf(".") >= 0 && this.value == ".")
                                    return;
                                screen.value += this.value;
                            }
                        } else { /*运算符*/
                            if (isNew == true) { //连续点击运算符
                                preOperator = this.value;
                                return;
                            }
                            isNew = true;
                            switch (preOperator) {
                                case "+":
                                    result += screen.value - 0;
                                    break;
                                case "-":
                                    result -= screen.value;
                                    break;
                                case "*":
                                    result *= screen.value;
                                    break;
                                case "/":
                                    result /= screen.value;
                                    break;
                            }
                            screen.value = result;
                            preOperator = this.value;
                        }
                    }
                }
            }
            var clear = document.getElementById("clear");
            clear.onclick = function(e) {
                screen.value = "0";
                isNew = true;
                result = "0";
                preOperator = "=";
            }
        </script>

© 著作权归作者所有

共有 人打赏支持
Lee12
粉丝 4
博文 12
码字总数 11258
作品 0
昆明
前端工程师
使用Ruby写的一个安卓语音计算器

RubyMotion使得能使用Ruby来写跨平台应用。 这里使用RubyMotion开发了一个简易的安卓语音计算器,https://github.com/ChenZhongPu/VoiceCalculator,UI界面和锤子计算器很像。...

chenzhongpu
2016/07/22
121
0
从编程小白到全栈开发:寻找代码中的问题

很少有人能一下子就写出完全没有问题的代码。工作良好的程序,都是经过一遍遍的反复测试运行、发现问题、剔除问题(也就是我们所说的找Bug和修Bug)过后的产物,经过了这一过程,程序才能最终...

一斤代码
01/11
0
0
JS制作一个简易计算器

//javascript简易计算器 <!DOCTYPE html><html> <head> <title> 事件</title> <script type="text/javascript"> function count(){ //获取第一个输入框的值 var node1=document.getElementB......

雨醉风尘
2015/09/02
2.1K
0
简易计算器

实现可连续运算的简易计算器。 E.g.,3 4=display 7=display 11=display 15..... [Code4App.com]

红薯
2013/08/06
1K
0
很着急,下午要交作业了,

要求做题个简易计算器,编好后运行起来就一个框框,点击没反应,求大大们帮我看看button1到18分别是1,2,3,4,5,6,7,8,9,0,.,=,+,-,*。/,作者 using System;using System.Collec...

小白兔
2010/12/28
312
10

没有更多内容

加载失败,请刷新页面

加载更多

下一页

go语言学习总结

一、描述 go语言是直接将源码编译成二进制机器码的语言;它支持面向对象、也支持函数式编程;支持并发很容易; 二、基本语法学习路径 https://studygolang.com/subject/2...

盼望明天
26分钟前
2
0
JSP 九大内置对象及其作用域

JSP 中一共预先定义了 9 个这样的对象,分别为:request、response、session、application、out、pagecontext、config、page、exception ,下面就简单介绍下。 1、request 对象 request 对象...

几个栗子
37分钟前
1
0
Java中的坑之方括号

Java中的坑之方括号 这一段时间,在做项目的时候,发现了一个坑,这个坑说大不大,说小不小,不知道的足够喝一壶,知道的就可以轻松解决。 问题描述 在做数据统计的时候,遇见了如下形式的数...

星汉
47分钟前
2
0
[雪峰磁针石博客]python机器学习、web开发等书籍汇总

Building Machine Learning Systems with Python Third Edition - 2018.pdf 下载地址 Get more from your data by creating practical machine learning systems with Python Key Features ......

python测试开发人工智能安全
58分钟前
1
0
文件的压缩与解压(linux)

Linux下*.tar.gz文件解压缩命令 1.压缩命令:   命令格式:tar -zcvf 压缩后文件名.tar.gz 被压缩文件名 可先切换到当前目录下。压缩文件名和被压缩文件名都可加入路径。 2.解压缩命令: ...

qimh
今天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部