java-SpringBoot框架開發計算器網頁端編程練習項目【web版】

今天分享一個使用springboot 寫一個 前后端不分離的項目,網頁計算器,來熟悉springboot框架的使用。
java版本:8。
springboot:2.6.13
使用的技術是:
Java + Spring Boot + Thymeleaf + HTML/CSS/JS 構建的 Web 端簡約按鈕式計算器。
熟悉 Spring Boot 控制器(@Controller, @GetMapping, @PostMapping)
· 掌握表單提交與參數綁定(@RequestParam)
· 學會使用 Thymeleaf 在前端綁定變量
· 理解 HTML 與 JS 如何聯動后端數據
先給大家看一下做出來的效果:
在這里插入圖片描述
項目部分代碼:

package com.jsonl.jisuanqi.controller;/**** User: Json* Date: 2025/6/21**/import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;/*** User:Json* Date: 2025/6/21**/
@Controller
public class IndexController {// 創建 JavaScript 腳本引擎,用于后端計算表達式private final ScriptEngine engine = new ScriptEngineManager().getEngineByName("JavaScript");// 顯示主頁面,初始化表達式為空@GetMapping("/")public String home(Model model) {model.addAttribute("expression", ""); // 頁面首次加載無表達式return "calculator"; // 返回 calculator.html}// 處理計算按鈕提交的表達式@PostMapping("/calculate")public String calculate(@RequestParam String expression, Model model) {try {// 若表達式為空或無效,設置錯誤信息if (expression == null || expression.trim().isEmpty()) {model.addAttribute("result", "錯誤");expression = "";} else {// 使用 JavaScript 引擎計算表達式結果Object result = engine.eval(expression);model.addAttribute("result", result.toString()); // 設置結果expression = result.toString(); // 把結果變成新表達式,支持連續計算}} catch (Exception e) {// 計算出錯時顯示“錯誤”model.addAttribute("result", "錯誤");expression = "";}// 將最新表達式返回頁面繼續顯示model.addAttribute("expression", expression);return "calculator";}// 清除表達式(點擊 C 時)@GetMapping("/reset")public String reset(Model model) {model.addAttribute("expression", "");model.addAttribute("result", "");return "calculator";}
}

在這里插入圖片描述
有興趣的小伙伴,可以拿去看看,希望能在你編程學習的過程中幫助到你。
完整代碼和簡單的操作說明已經打包好了。可以獲取:
https://wwwoop.com/home/Index/projectInfo?goodsId=92&typeParam=2&subKey=1

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/88346.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/88346.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/88346.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

linux操作系統的軟件架構分析

一、linux操作系統的層次結構 1.內核的主要功能 1)進程管理 2)內存管理 3)文件系統 4)進程間通信、I/O系統、網絡通信協議等 2.系統程序 1)系統接口函數庫,比如libc 2)shell程序 3)編譯器、編輯…

淺談Java對象在內存中的存儲形式

我們知道計算機以二進制的方式存儲數據,以 64 位虛擬機為例,Java 對象在內存中的存儲形式為: 開頭是 8 個字節的 markword,用于標記對象的狀態。(也就是一個 long 型數據的大小。不妨記作對象頭里有一個長長的 markwo…

Android 開發問題:Wrong argument type for formatting argument ‘#2‘ in info_message

<string name"info_message">name: %1$s, age: %2$d</string>String str getString(R.string.info_message, "zs");在 Android 開發中&#xff0c;上述代碼&#xff0c;出現如下警告信息 Wrong argument type for formatting argument #2 in…

Vue+spring boot前后端分離項目搭建---小白入門

首先&#xff0c;介紹一下軟件準備工作 1.vscode 2.maven 3.vue搭建&#xff1a;node.jsyarnvite 一.后端搭建 打開vscode,建立一個springboot項目&#xff0c;參考鏈接&#xff1a;sping boot項目搭建 建立一個項目&#xff0c;目錄結構如下&#xff1a; helloController.java…

“蘇超”拉動周末消費,抖音生活服務:比賽城市迎來普遍消費上漲

“蘇超”爆火&#xff0c;有力拉升了緊隨賽程的周末消費。抖音生活服務數據顯示&#xff0c;剛剛過去的周末&#xff08;6月21日至22日&#xff09;&#xff0c;江蘇商圈休閑運動團購訂單消費環比增長225%&#xff0c;到店消費金額環比增長181%。雖然幾個比賽城市周末天氣欠佳&…

使用python開發一個exe版本的計算器項目練習

最近在練習python開發軟件&#xff0c;就開發了一個 客戶端版的 計算器。先給大家看一下 做出來的樣子 python版本&#xff1a;3.8 以上 主要是 使用 import tkinter as tk 這個庫來實現圖形界面開發 代碼還是比較簡單的&#xff1a; # 創建主窗口 root tk.Tk() root.title…

uniapp開發小程序,導出文件打開并保存,實現過程downloadFile下載,openDocument打開

uniapp開發小程序&#xff0c;導出文件打開并保存 實現思路 1、調用請求獲取到后端接口返回的下載文件的url路徑 &#xff08;注意必須是https的路徑&#xff0c;域名需要配置在微信小程序后臺的合法域名里面&#xff09; 2、使用 uni.downloadFile 方法 &#xff08;下載文件…

vue2中前端實現圖片裁剪上傳到服務器

在 Vue 2 中實現圖片裁剪并上傳到服務器&#xff0c;你可以結合使用 Cropper.js 來進行圖片裁剪&#xff0c;并通過 Axios 或者其他 HTTP 客戶端庫將裁剪后的圖片上傳至服務器。以下是一個基本的實現步驟和示例代碼&#xff1a; 步驟 安裝依賴&#xff1a;你需要安裝 cropperj…

C# 網絡編程-關于HttpWebRequest使用方式(二)

項目開發用到數據請求時候&#xff0c;會用的到HttpWebRequest的請求方式&#xff0c;主要涵蓋GET、POST、PUT、DELETE等方法 一、HttpWebRequest簡介 HttpWebRequest是.NET Framework中用于發送HTTP請求的核心類&#xff0c;適用于構建HTTP客戶端。它支持GET、POST、PUT、DE…

git變更記錄

目錄 wvp-ui -new Dji 10.60.2.175:8000上的編譯 個人拉分支 目前約定2025-06-25 wvp-ui -new branch new BASE_URL /new/ ci-cd : wvp-newui Config [Jenkins] 禁 用 10.30.2.8 ssh 10.30.2.8 /home/dualven/wvp-server/deployNewUi.sh Dji 主分支的構建&#xf…

前端如何禁止用戶復制?

禁用右鍵菜單 document.addEventListener(contextmenu, function(e) {e.preventDefault(); });禁用快捷鍵&#xff08;CtrlC/X/A等&#xff09; document.addEventListener(keydown, function(e) {if (e.ctrlKey && [c, x, v, a].includes(e.key.toLowerCase())) {e.…

阿里云無影:開啟云端辦公娛樂新時代

阿里云無影云電腦&#xff1a;打破傳統束縛&#xff0c;暢享云端自由 在數字化浪潮洶涌澎湃的當下&#xff0c;云計算技術持續革新&#xff0c;為我們的工作與生活帶來前所未有的變革。阿里云作為云計算領域的佼佼者&#xff0c;推出的無影云電腦無疑是一顆璀璨的明星&#xf…

Windows 和 macOS 串口調試軟件

在 Windows 和 macOS 上&#xff0c;你可以使用以下串口調試軟件來查看開發板的打印信息。以下是常見且好用的工具推薦&#xff1a; Windows 推薦工具 PuTTY 免費、輕量級&#xff0c;支持串口&#xff08;COM&#xff09;和 SSH/Telnet下載地址&#xff1a;https://www.putty.…

Redis 的作用及詳細分析

網上查詢總結了一下Redis相關的信息 記錄一下 &#xff0c;有問題的地方&#xff0c;望多加指正&#xff0c;我們共同學習。 什么是Redis Redis是一款內存高速緩存數據庫。Redis全稱為&#xff1a;Remote Dictionary Server &#xff08;遠程數據服務&#xff09;&#xff0c;…

【邊緣計算】引論基礎

&#xff08;1&#xff09;在不遠的未來&#xff0c;將有超過50%的數據需要在網絡邊緣側分析、處理與儲存。智能互聯的網絡邊緣側將會面臨如下挑戰&#xff1a; 聯接設備的海量與異構 隨著聯接設備數量的劇增&#xff0c;網絡運維管理、靈活擴展和可靠性保障都面臨著巨大挑戰。…

SpringBoot中4種登錄驗證碼實現方案

文章目錄 詳解方案一&#xff1a;基于kaptcha的圖形驗證碼實現步驟 方案二&#xff1a;基于短信驗證碼實現步驟 方案三&#xff1a;基于Spring Mail的郵箱驗證碼實現步驟 方案四&#xff1a;基于AJ-Captcha的滑動拼圖驗證碼實現步驟 總結 詳解 在Web應用中&#xff0c;驗證碼是…

基于版本控制+WORM的OSS數據保護:防勒索攻擊與法規遵從實踐

1. 數據保護的核心挑戰與解決方案架構 &#xff08;1&#xff09;現代數據保護的三大矛盾 勒索軟件進化 vs 傳統備份脆弱性&#xff1a;攻擊者已掌握備份系統刪除技術&#xff08;如vssadmin delete shadows&#xff09;法規保留要求&#xff08;GDPR第17條&#xff09;vs 技…

混合架構入門:如何選組合恰當的云 + 私有節點?

如果你最近剛開始搭建業務系統&#xff0c;或者準備從傳統IDC遷移到云上&#xff0c;你很可能已經被“混合云”、“多云”、“私有部署”這些概念繞得頭暈。而今天這篇文章&#xff0c;不會再羅列概念或抄定義&#xff0c;而是站在一個運維工程師、架構規劃者的角度&#xff0c…

CDN+OSS邊緣加速實踐:動態壓縮+智能路由降低30%視頻流量成本(含帶寬峰值監控與告警配置)

1 背景與挑戰分析 &#xff08;1&#xff09;流量成本結構剖析 視頻業務帶寬成本公式&#xff1a; C_{total} \sum_{i1}^{n} (P_{peak_i} T_i R_{region}) C_{req} N_{req}其中 P p e a k P_{peak} Ppeak? 為區域峰值帶寬&#xff08;GB/s&#xff09;&#xff0c; T …

Flink內存配置

通過本文可以解決以下3個問題。 了解flink內存和配置項相關概念。清楚UI中TM和JM各內存組件實際內存值的計算規則。根據實際情況對內存進行調整。 1. Flink進程內存 TM和JM二者均為JVM進程&#xff08;JVM通常分成堆內和堆外兩部分&#xff09;。TM和JM的內存定義為進程總內…