iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >使用JS实现简单计算器的方法
  • 523
分享到

使用JS实现简单计算器的方法

2023-06-14 18:06:06 523人浏览 薄情痞子
摘要

今天小编给大家分享的是使用js实现简单计算器的方法,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。JS是什么JS是javascript的简称,它是一种直译式的脚本语言,其解释器被称为J

今天小编给大家分享的是使用js实现简单计算器的方法,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。

JS是什么

JS是javascript的简称,它是一种直译式的脚本语言,其解释器被称为JavaScript引擎,是浏览器的一部分,主要用于WEB开发,可以给网站添加各种各样的动态效果,让网页更加美观。

JS实现简单计算器

页面布局设计(HTML+CSS)

  由于在之前的博客中有对htmlCSS进行详细的讲解,再次就不多叙述,直接上代码。因为js中用到了Jquery选择器所以在html中使用<script></script>标签引入了JQuery,在html中为每个按钮单击绑定计算器事件cal()并传入当前点击对象this。
  .html文件:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>简单计算器</title>    <link rel="stylesheet" type="text/css" href="./style.css"> <!-- css样式 -->       <script src="https://code.jquery.com/jquery-latest.min.js"></script> <!-- 引用JQuery库 --></head><body>    <p>        <table>            <tr>                <td colspan="3"><input type="text" value="0"/></td>            </tr>            <tr>                <td><button id="c11" onclick="cal(this)">+</button></td>                <td><button id="c12" onclick="cal(this)">-</button></td>                <td><button id="c13" onclick="cal(this)">×</button></td>                <td><button id="c14" onclick="cal(this)">/</button></td>            </tr>            <tr>                <td><button id="c21" onclick="cal(this)" value="7">7</button></td>                <td><button id="c22" onclick="cal(this)" value="8">8</button></td>                <td><button id="c23" onclick="cal(this)" value="9">9</button></td>                <td rowspan="2"><button id="c24" onclick="cal(this)">C</button></td>            </tr>            <tr>                <td><button id="c31" onclick="cal(this)" value="4">4</button></td>                <td><button id="c32" onclick="cal(this)" value="5">5</button></td>                <td><button id="c33" onclick="cal(this)" value="6">6</button></td>            </tr>            <tr>                <td><button id="c41" onclick="cal(this)" value="1">1</button></td>                <td><button id="c42" onclick="cal(this)" value="2">2</button></td>                <td><button id="c43" onclick="cal(this)" value="3">3</button></td>                <td rowspan="2"><button id="c44" onclick="cal(this)">=</button></td>            </tr>            <tr>                <td colspan="2"><button id="c51" onclick="cal(this)" value="0">0</button></td>                <td><button id="c53" onclick="cal(this)">.</button></td>            </tr>        </table>    </p>    <script src = "./calculator.js"></script> <!-- js脚本 --></body></html>

  .css文件:

input{    width: 200px;    height:50px;    margin-bottom: 10px;    padding: 0;    font:18px bold;}button{    width: 50px;    height: 40px;    margin-bottom: 10px;    border: 1px dashed black;    background-color: #ffc4cc;}#c24{    height: 93px;}#c44{    height: 93px;}#c51{    width: 122px;}#c44,#c24,#c14{    margin-left:10px;}

  静态页面如图示:
使用JS实现简单计算器的方法

实现计算部分(JS)

1.功能:实现简单的数值的加减乘除计算,以及清屏功能
2.操作:例如:123×29;以此点击1、2、3、,点击×号,依次点击2、9,最后点击=,即可计算出结果3567
示例如图:使用JS实现简单计算器的方法
使用JS实现简单计算器的方法
3.缺点:

  • 不能进行负数的计算,会产生NaN错误;

  • 不能进行连续计算,一次只能进行两个数之间的运算;如果要在之前结果上继续计算可以直接按运算符号和下一个数;若要开始新的计算,则需要先清屏。

4.思路展示:

  • 文本框显示:因为文本框显示的内容根据点击的按钮实时变化,为了修改简单,在这里使用JQuery选择器选中文本框,赋值给一个全局变量input,之后我们根据input的val()方法修改它的值就好。

代码如下:

var input = $("input");
  • 按钮id获取:因为后面我们要根据不同的按钮进行不同的操作,所以在cal()函数中第一步先获取按钮的id,方便后面做判断用。

代码如下:

let btn = e.id;
  • 数值输入:根据按钮的id判断是否为数字或者小数点,如果是的话,进行数字输入操作。先判断当前文本框的值是不是0,如果是0,则用当前输入覆盖input的值;若非0,则将当前输入连接在input值后面。

代码如下:

//若input的值为0input.val(btn_value);//若input的值非0input.val(input.val()+btn_value);
  • 符号输入:根据按钮的id判断是否为运算符号,如果是的话,进行符号输入操作。不考虑连续运算,则先判断当前文本框的值是否含有+、×、/(不考虑-是因为要进行减法运算),如果有,则弹出“不支持该运算”;若无,则将该运算符号连接在input值后面。

代码如下:

//若input的值含有+、×、/ alert("连续运算功能未上线!")//若input的值不含有+、×、/input.val(input.val()+当前运算符号);
  • 数值计算:根据按钮的id判断是否为等号,如果是的话,进行数值计算操作。进行选择判断,使用indexOf()方法判断input的值中含有+、×、/哪个标点符号,然后以该符号位置为分隔,使用substring()方法截取该符号前面的值强制转化为Float型后赋值给num1,截取该符号后面的值强制转化为Float型后赋值给num2,进行相应的计算。(注意除法时分母不能为0)

代码如下:

if(input_value.indexOf("+")!==-1){        pos = input_value.indexOf("+");        num1 = parseFloat(input_value.substring(0,pos));        num2 = parseFloat(input_value.substring(pos+1,input_value.length));        input.val(num1+num2);    }    else  if(input_value.indexOf("-")!==-1){        pos = input_value.indexOf("-");        num1 = parseFloat(input_value.substring(0,pos));        num2 = parseFloat(input_value.substring(pos+1,input_value.length));        input.val(num1-num2);    }    else  if(input_value.indexOf("×")!==-1){        pos = input_value.indexOf("×");        num1 = parseFloat(input_value.substring(0,pos));        num2 = parseFloat(input_value.substring(pos+1,input_value.length));        input.val(num1*num2);    }    else  if(input_value.indexOf("/")!==-1){        pos = input_value.indexOf("/");        num1 = parseFloat(input_value.substring(0,pos));        num2 = parseFloat(input_value.substring(pos+1,input_value.length));        if(num2-0 === 0){            alert("分母不能为0!");        }        else{            input.val(num1/num2);        }    }
  • 清屏:根据按钮的id判断是否为符号C,如果是的话,进行清屏操作。

代码如下:

input.val(0);

5. JavaScript文件如下:

"use strict"var input = $("input");function cal(e){    let btn = e.id;    //清零    if( btn === "c24"){        input.val(0);    }    //数值输入    else if(btn === "c51"||btn === "c41"||btn === "c42"||btn === "c43"        ||btn === "c31"||btn === "c32"||btn === "c33"        ||btn === "c21"||btn === "c22"||btn === "c23"){        let btn_value = document.getElementById(btn).getAttribute("value");        if( input.val() === "0" ){            input.val(btn_value);        }        else{            input.val(input.val()+btn_value);        }    }    else if(btn === "c11"){        let input_value = input.val();        if(input_value.indexOf("+") === -1&&input_value.indexOf("-") === -1            &&input_value.indexOf("×") === -1&&input_value.indexOf("/") === -1){            input.val(input.val()+"+");        }        else{            alert("连续运算功能未上线!")        }    }    else if(btn === "c12"){        let input_value = input.val();        if(input_value.indexOf("+") === -1&&input_value.indexOf("-") === -1            &&input_value.indexOf("×") === -1&&input_value.indexOf("/") === -1){            input.val(input.val()+"-");        }        else{            alert("连续运算功能未上线!")        }    }    else if(btn === "c13"){        let input_value = input.val();        if(input_value.indexOf("+") === -1&&input_value.indexOf("-") === -1            &&input_value.indexOf("×") === -1&&input_value.indexOf("/") === -1){            input.val(input.val()+"×");        }        else{            alert("连续运算功能未上线!")        }    }    else if(btn === "c14"){        let input_value = input.val();        if(input_value.indexOf("+") === -1&&input_value.indexOf("-") === -1            &&input_value.indexOf("×") === -1&&input_value.indexOf("/") === -1){            input.val(input.val()+"/");        }        else{            alert("连续运算功能未上线!")        }    }    else if(btn === "c53"){        input.val(input.val()+".");    }    else if(btn === "c44"){        let pos,num1,num2;        let input_value = input.val();        if(input_value.indexOf("+")!==-1){            pos = input_value.indexOf("+");            num1 = parseFloat(input_value.substring(0,pos));            num2 = parseFloat(input_value.substring(pos+1,input_value.length));            input.val(num1+num2);        }        else  if(input_value.indexOf("-")!==-1){            pos = input_value.indexOf("-");            num1 = parseFloat(input_value.substring(0,pos));            num2 = parseFloat(input_value.substring(pos+1,input_value.length));            input.val(num1-num2);        }        else  if(input_value.indexOf("×")!==-1){            pos = input_value.indexOf("×");            num1 = parseFloat(input_value.substring(0,pos));            num2 = parseFloat(input_value.substring(pos+1,input_value.length));            input.val(num1*num2);        }        else  if(input_value.indexOf("/")!==-1){            pos = input_value.indexOf("/");            num1 = parseFloat(input_value.substring(0,pos));            num2 = parseFloat(input_value.substring(pos+1,input_value.length));            if(num2-0 === 0){                alert("分母不能为0!");            }            else{                input.val(num1/num2);            }        }    }}

关于使用JS实现简单计算器的方法就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。

--结束END--

本文标题: 使用JS实现简单计算器的方法

本文链接: https://www.lsjlt.com/news/274254.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 使用JS实现简单计算器的方法
    今天小编给大家分享的是使用JS实现简单计算器的方法,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。JS是什么JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器被称为J...
    99+
    2023-06-14
  • 如何使用HTML和JS实现简单的计算器
    这篇文章主要介绍了如何使用HTML和JS实现简单的计算器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。   <!doctypehtm...
    99+
    2022-10-19
  • 使用JS实现简易计算器
    使用JS完成简易计算器,供大家参考,具体内容如下 要求:输入的值只能是数字,使用正则表达式 onchange():值改变时执行事件 onblur():鼠标移出时执行事件 <...
    99+
    2022-11-12
  • js如何实现简单的计算器功能
    这篇文章主要介绍js如何实现简单的计算器功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!示例代码:<!DOCTYPE html>...
    99+
    2022-10-19
  • 原生JS实现简单计算器功能
    本文实例为大家分享了JS实现简单计算器功能的具体代码,供大家参考,具体内容如下 使用html和css写出计算器的基本结构和样式,用原生JS实现计算器的加减乘除运算功能,只能计算简单的...
    99+
    2022-11-13
  • JS实现简单计数器
    用HTML CSS和JavaScript实现简单计数器,有加、减和零三个按钮,分别实现加一、减一和归零操作。下面先看一下效果图。 HTML代码 <div class="b...
    99+
    2022-11-12
  • 基于HTML+JS实现简单的年龄计算器
    目录前言演示效果HTML代码CSS代码Javascript代码演示地址前言 在线演示地址:http://haiyong.site/age-calculator JavaScript提...
    99+
    2022-11-12
  • Android实现简单加法计算器
    本文实例为大家分享了Android实现简单加法计算器的具体代码,供大家参考,具体内容如下 package com.example.calculator; import an...
    99+
    2022-06-06
    Android
  • 原生JS怎么实现简单计算器功能
    本篇内容主要讲解“原生JS怎么实现简单计算器功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“原生JS怎么实现简单计算器功能”吧!使用html和css写出计算器的基本结构和样式,用原生JS实现计...
    99+
    2023-06-29
  • 用javascript实现简单计算器
    本文实例为大家分享了javascript实现简单计算器的具体代码,供大家参考,具体内容如下 设计一个简单的计算器 代码 <body> <a>第一个...
    99+
    2022-11-12
  • swift实现简单的计算器
    本文实例为大家分享了swift实现简单计算器的具体代码,供大家参考,具体内容如下 代码 // //  ViewController.swift //  Calculator // ...
    99+
    2022-11-13
  • PHP实现简单计算器
    目录 一、题目:  二、基本界面设计代码:  三、分析: 四、实现编程三个步骤 五、完整实现代码 一、题目:     题目描述:下列列表框中有+、-、*、/四种运算符,选择不同的运算符进行,单击计算按钮进行不同的计算。   二、基本界...
    99+
    2023-10-01
    php
  • jQuery实现简单计算器
    本文实例为大家分享了jQuery实现简单计算器的具体代码,供大家参考,具体内容如下 基本功能: 1、计算器换肤,目前有白色(默认色)、绿色、蓝色、灰色、橙色几种颜色可供选择。 2、简...
    99+
    2022-11-13
  • unity实现简单计算器
    本文实例为大家分享了unity实现简单计算器的具体代码,供大家参考,具体内容如下 using System.Text; using UnityEngine; using Unit...
    99+
    2022-11-12
  • Android实现简单计算器
    本文实例为大家分享了Android实现简单计算器的具体代码,供大家参考,具体内容如下 功能 1、加减乘除四则运算 2、归0 3、回退 4、即时运算 配置 在build.gradle...
    99+
    2022-11-12
  • Swift实现简单计算器
    本文实例为大家分享了Swift实现简单计算器的具体代码,供大家参考,具体内容如下 使用Storyboard 快速而又方便的进行控件的布局,功能操作简单的进行一些运算; 代码实现 //...
    99+
    2022-11-13
  • js如何实现日历的简单算法
    这篇文章将为大家详细讲解有关js如何实现日历的简单算法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。最近有用到日历可需要编辑文本的日历,为了...
    99+
    2022-10-19
  • js实现一个简易的计算器
    利用原生js实现一个简易的计算器(附详细注释),供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en"> <...
    99+
    2022-11-12
  • 使用Javascript如何实现简单计算器
    小编给大家分享一下使用Javascript如何实现简单计算器,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体内容如下1.htm...
    99+
    2022-10-19
  • JS怎么实现简易计算器
    这篇文章主要介绍了JS怎么实现简易计算器的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JS怎么实现简易计算器文章都会有所收获,下面我们一起来看看吧。 一、题目描述 用户在弹...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作