0

0

如何用 PHP 表单调用计算器类并执行四则运算

花韻仙語

花韻仙語

发布时间:2026-03-15 14:50:01

|

658人浏览过

|

来源于php中文网

原创

如何用 PHP 表单调用计算器类并执行四则运算

本文教你如何构建一个 html 表单,安全接收两个数字输入,并通过 post 提交后,动态实例化 php 计算器类,根据用户选择的运算类型(加、减、乘、除)调用对应方法返回结果。

本文教你如何构建一个 html 表单,安全接收两个数字输入,并通过 post 提交后,动态实例化 php 计算器类,根据用户选择的运算类型(加、减、乘、除)调用对应方法返回结果。

在 Web 开发中,将表单数据与面向对象的 PHP 类协同工作是基础但关键的技能。初学者常误用 <input type="button"> 试图直接触发服务器端逻辑——但这类按钮默认不提交表单,也无法传递操作意图;真正适合“选择操作类型”的是 单选按钮(radio),它能将用户意图(如 operation=add)随表单一同提交至服务端。

以下是一个完整、安全、可运行的实现方案:

灵机语音
灵机语音

灵机语音

下载

✅ 正确结构:表单 + 类 + 条件调用

<?php
class MyCalculator {
    private $first, $second; // 推荐使用 private 封装属性

    public function __construct($fval, $sval) {
        $this->first  = (float)$fval;
        $this->second = (float)$sval;
    }

    public function add() {
        return $this->first + $this->second;
    }

    public function subtract() {
        return $this->first - $this->second;
    }

    public function multiply() {
        return $this->first * $this->second;
    }

    public function divide() {
        if ($this->second == 0) {
            throw new InvalidArgumentException("Division by zero is not allowed.");
        }
        return $this->first / $this->second;
    }
}
?>

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>PHP 四则运算计算器</title>
    <style>
        body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; margin: 2rem; }
        .form-group { margin: 1rem 0; }
        label { display: inline-block; width: 80px; }
        input[type="number"], input[type="radio"] { margin-left: 0.5rem; }
        .result { margin-top: 1.5rem; padding: 0.75rem; background: #f0f8ff; border-left: 4px solid #4285f4; }
    </style>
</head>
<body>

<h2>简易计算器</h2>

<form method="post" action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>">
    <div class="form-group">
        <label for="num-a">数值 A:</label>
        <input type="number" id="num-a" name="num-a" step="any" required>
    </div>

    <div class="form-group">
        <label for="num-b">数值 B:</label>
        <input type="number" id="num-b" name="num-b" step="any" required>
    </div>

    <div class="form-group">
        <label>选择运算:</label><br>
        <label><input type="radio" name="operation" value="add" required> 加法 (+)</label><br>
        <label><input type="radio" name="operation" value="subtract"> 减法 (−)</label><br>
        <label><input type="radio" name="operation" value="multiply"> 乘法 (×)</label><br>
        <label><input type="radio" name="operation" value="divide"> 除法 (÷)</label>
    </div>

    <button type="submit">计算</button>
</form>

<?php
// ✅ 关键:仅在表单提交且数据完整时执行计算
if ($_SERVER['REQUEST_METHOD'] === 'POST' 
    && isset($_POST['num-a'], $_POST['num-b'], $_POST['operation'])) {

    $a = trim($_POST['num-a']);
    $b = trim($_POST['num-b']);
    $op = $_POST['operation'];

    // 基础校验:确保为有效数字
    if (!is_numeric($a) || !is_numeric($b)) {
        echo '<div class="result">❌ 错误:请输入有效的数字。</div>';
    } else {
        try {
            $calc = new MyCalculator($a, $b);
            $result = null;

            switch ($op) {
                case 'add':      $result = $calc->add();      break;
                case 'subtract': $result = $calc->subtract(); break;
                case 'multiply': $result = $calc->multiply(); break;
                case 'divide':   $result = $calc->divide();   break;
                default:         throw new InvalidArgumentException("不支持的操作:{$op}");
            }

            echo '<div class="result">✅ 运算结果:<strong>' . htmlspecialchars($result) . '</strong></div>';

        } catch (InvalidArgumentException $e) {
            echo '<div class="result">❌ 计算错误:' . htmlspecialchars($e->getMessage()) . '</div>';
        }
    }
}
?>
</body>
</html>

⚠️ 注意事项与最佳实践

  • 安全性优先:始终对 $_POST 数据做 isset() 检查和类型/范围校验;使用 htmlspecialchars() 防止 XSS 输出;
  • 避免 type="button":它不提交表单,若需 JS 交互请配合 AJAX;本例纯服务端处理,必须用 type="submit" 或隐式提交(如 radio + submit button);
  • 健壮性增强
    • 使用 (float) 强制转换确保数值类型;
    • 除零检查应在类方法内完成(已示例);
    • required 属性提升前端体验,但不可替代后端校验
  • 用户体验优化:添加 CSS 样式、语义化标签(<label for>)、step="any" 支持小数输入;
  • 扩展建议:后续可增加「运算历史记录」、「支持负数/科学计数」或封装为 Composer 包复用。

掌握这一模式,你已具备连接表单与业务逻辑的核心能力——下一步可尝试将计算器升级为支持链式运算或 RESTful API 接口。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

162

2023.12.25

PHP API接口开发与RESTful实践
PHP API接口开发与RESTful实践

本专题聚焦 PHP在API接口开发中的应用,系统讲解 RESTful 架构设计原则、路由处理、请求参数解析、JSON数据返回、身份验证(Token/JWT)、跨域处理以及接口调试与异常处理。通过实战案例(如用户管理系统、商品信息接口服务),帮助开发者掌握 PHP构建高效、可维护的RESTful API服务能力。

179

2025.11.26

ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

166

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

124

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

260

2024.09.24

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

595

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

108

2025.10.23

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.6万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号