js实现简单的计算器

<script>
    //接收所有按钮的变量
    var btnlist=null;
    //接收所有屏幕上的值
    var screenIpt=null;
    //接收用户的屏幕值和符号值
    var result="";
    //设置一个Boolean类型的值
    var ischange=null;
    //浏览器加载完成事件
    window.onload=function(){
        //获取元素
        btnlist=document.getElementsByClassName("btn");
        screenIpt=document.getElementById("script");
        //执行方法绑定事件
        addBtnHandle();
    }
    //构建方法给所有的按钮添加事件监听
    function addBtnHandle(){
        for(var i=0;i<btnlist.length;i++){
            btnlist[i].addEventListener("click",listen);
        }
    }
    //所有按钮的事件回调函数
    function listen(){
        //点击事件触发该方法
        //console.log(this);//this指向的是当前操作对象
        //1.将获取的值给屏幕  2.只让数字和小数点显示到屏幕上
        if(!isNaN(this.innerText)||this.innerText=='.'){
            ischange=false;
            //3.是数字的时候,考虑屏幕的值是否为0
            if(screenIpt.value=='0'){
                //5.如果用户按的是点,并且屏幕值为0
                screenIpt.value=this.innerText=='.'?'0.':this.innerText;
                screenIpt.value=this.innerText;
            }
            else{
                //4.检测屏幕上只能有一个点
                if(screenIpt.value.indexOf('.')!=-1){
                    //有点,不能再有小数点
                    if(this.innerText!='.'){
                        screenIpt.value+=this.innerText;
                    }
                }
                else{
                    //没点,可以有小数点
                    screenIpt.value+=this.innerText;
                }

            }
        }
        else{
            //除数字和小数点的其他值
            if(ischange){
                var len=result.substring(0,result.length-1);
                if(this.innerText=='='){
                    var res=eval(len);
                    //最后一位
                    var lastchat=result.substr(result.length-1,1);
                    screenIpt.value=eval(res+lastchat+res);
                    ischange=false;
                    result="";
                }
                else{
                    result=len+this.innerText;
                }
                return;
            }
            //输出表达式
            console.log(result);
            //记录屏幕当前值
            result+=screenIpt.value;

            switch (this.innerText){
                case 'AC':
                    screenIpt.value=0;
                    result='';
                    break;
                case 'DEL':
                    var val=screenIpt.value;
                    screenIpt.value=val.length>1?val.substring(0,val.length-1):0;
                    break;
                case '=':
                    //计算表达式eval()
                    var res=eval(result);
                    console.log(res);
                    screenIpt.value=res;
                    res="";
                    break;
                default :
                    //先让屏幕清零
                    screenIpt.value=0;
                    //+-*/
                    ischange=true;
                    result+=this.innerHTML;
                    break;
            }
        }

    }
</script>

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南初️

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值