【无标题】

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

// 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.运行();
相关推荐
lichenyang4534 小时前
Docker 学习笔记(一):为什么需要镜像、容器和仓库?
前端
kyriewen4 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
IT_陈寒4 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
free355 小时前
从 0 实现一个 Tiny JavaScript VM:项目架构拆解
javascript
暴走的小呆5 小时前
Vue 2 中 Object 的变化侦测:从 getter/setter 到 Dep、Watcher、Observer
vue.js
奇奇怪怪的5 小时前
Embedding 模型 10+ 横向评测
前端
陈广亮5 小时前
Monorepo 从 0 到 1 实操指南 2026 版:pnpm catalogs + Turborepo 2.x + changesets 全链路
前端
子兮曰5 小时前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
敲代码的鱼5 小时前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
英勇无比的消炎药5 小时前
TinyVue v-auto-tip: 文本超长自动提示的优雅方案
vue.js