【无标题】

建议计算器,显示:欢迎使用建议计算器

// 1.加法运算

// 2.减法运算

// 3.乘法运算

// 4.除法运算

// 5.退出计算器

// 请输入您的选项:

// 实现化一个建议计算器对象,该对象要有以上功能,用户输入数字,点击运算符,显示结果,点击退出按钮,结束程序

// 实现化一个建议计算器对象,该对象要有以上功能,用户输入数字,点击运算符,显示结果,点击退出按钮,结束程序

// 实现化一个建议计算器对象,该对象要有以上功能,用户输入数字,点击运算符,显示结果,点击退出按钮,结束程序

function Calculator() {

// 显示欢迎信息

this.欢迎使用建议计算器 = function() {

console.log('欢迎使用简易计算器');

}

复制代码
// 显示运算符菜单

    this.显示运算符 = function() {
        console.log('运算符菜单:');
        console.log('1.加法运算');
        console.log('2.减法运算');
        console.log('3.乘法运算');
        console.log('4.除法运算');
        console.log('5.退出计算器');
    }

    // 加法运算
    this.加法运算 = function(a,b) {
        let result = a + b;
        console.log(a + ' + ' + b + ' = ' + result);
        alert(a + ' + ' + b + ' = ' + result);
    }

    // 减法运算
    this.减法运算 = function(a,b) {
        let result = a - b;
        console.log(a + ' - ' + b + ' = ' + result);
        alert(a + ' - ' + b + ' = ' + result);
    }

    // 乘法运算
    this.乘法运算 = function(a,b) {
        let result = a * b;
        console.log(a + ' × ' + b + ' = ' + result);
        alert(a + ' × ' + b + ' = ' + result);
    }

    // 除法运算(包含零除检查)
    this.除法运算 = function(a,b) {
        if (b === 0) {
            console.log('错误:除数不能为零');
            alert('错误:除数不能为零');
        } else {
            let result = a / b;
            console.log(a + ' ÷ ' + b + ' = ' + result);
            alert(a + ' ÷ ' + b + ' = ' + result);
        }
    }

    // 退出计算器
    this.退出计算器 = function() {
        console.log('感谢使用简易计算器,再见!');
        alert('感谢使用简易计算器,再见!');
    }

    // 获取用户输入的选项
    this.请输入您的选项 = function() {
        let option = prompt(`
        请输入您的选项:
        1.加法运算
        2.减法运算
        3.乘法运算
        4.除法运算
        5.退出计算器
        请输入您的选项:`);
        // 去除空格并返回
        return option ? option.trim() : '';
    }

    // 获取用户输入的数字
    this.请输入数字 = function(promptText) {
        let num = prompt(promptText);
        num = parseFloat(num);
        // 如果不是有效数字,重新输入
        while (isNaN(num)) {
            num = prompt('输入无效,请重新输入数字:');
            num = parseFloat(num);
        }
        return num;
    }

    // 运行计算器主循环
    this.运行 = function() {
        this.欢迎使用建议计算器();
        
        while (true) {
            this.显示运算符();
            let option = this.请输入您的选项();
            
            switch (option) {
                case '1': {
                    let a = this.请输入数字('请输入第一个数字:');
                    let b = this.请输入数字('请输入第二个数字:');
                    this.加法运算(a, b);
                    break;
                }
                case '2': {
                    let a = this.请输入数字('请输入第一个数字:');
                    let b = this.请输入数字('请输入第二个数字:');
                    this.减法运算(a, b);
                    break;
                }
                case '3': {
                    let a = this.请输入数字('请输入第一个数字:');
                    let b = this.请输入数字('请输入第二个数字:');
                    this.乘法运算(a, b);
                    break;
                }
                case '4': {
                    let a = this.请输入数字('请输入被除数:');
                    let b = this.请输入数字('请输入除数:');
                    this.除法运算(a, b);
                    break;
                }
                case '5': {
                    this.退出计算器();
                    return; // 退出循环
                }
                default: {
                    console.log('输入错误,请输入1-5之间的数字');
                    alert('输入错误,请输入1-5之间的数字');
                }
            }
        }
    }
}

// 创建计算器实例并运行
let myCalculator = new Calculator();
myCalculator.运行();
相关推荐
Highcharts.js几秒前
数学函数双曲线音频图表(y=1/x 双曲线)|图表代码示例
前端·react.js·实时音视频·highcharts·音频图表·双曲线图表
放下华子我只抽RuiKe55 分钟前
React 从入门到生产(一):JSX 与组件思维
前端·javascript·人工智能·pytorch·深度学习·react.js·前端框架
冴羽yayujs29 分钟前
JavaScript 9 个先有库再有 API 的故事
开发语言·javascript·ecmascript
m0_7510186635 分钟前
docker 安装 nginx
vue.js·nginx·docker
油丶酸萝卜别吃1 小时前
JavaScript 深度合并函数 deepMerge 实现指南(附完整测试用例)
开发语言·javascript·测试用例
问心无愧05131 小时前
ctf show web 入门152
前端·笔记
kyriewen1 小时前
Copilot下个月按Token收钱,我算了一笔账:重度用户一年要多花3000块
前端·javascript·openai
zyl837211 小时前
3Dmol.js + Vue3快速上手
vue.js
镜宇秋霖丶1 小时前
2026.5.18@霖宇博客制作中遇见的问题
vue.js
还有多久拿退休金1 小时前
dnd-kit 碰撞检测算法:你的订单为什么自己"跑"到了 1 号?
前端