小學四則運算練習題網頁版結對項目報告

来源:https://www.cnblogs.com/Apriler/archive/2019/04/10/10686986.html
-Advertisement-
Play Games

一.項目結構 二.計算模塊和界面模塊間的調用 三.頁面演示效果 四.遇到問題 五.知識點記錄 六.新知識新技能 七.未實現但計劃實現功能 八.學習目標與總結 項目地址:https://git.dev.tencent.com/hey_wuqw/webArithmetic.git 一.項目結構 二. 計 ...


一.項目結構

二.計算模塊和界面模塊間的調用

三.頁面演示效果

四.遇到問題

五.知識點記錄

六.新知識新技能

七.未實現但計劃實現功能

八.學習目標與總結


項目地址:https://git.dev.tencent.com/hey_wuqw/webArithmetic.git


一.項目結構

二. 計算模塊和界面模塊間的調用

三.頁面演示效果



四.遇到問題

1.check()方法(用於接收答題頁面傳來的參數,請求從answer.jsp(答題界面)轉發到result.jsp(做題結果界面))需要訪問makeQ()方法中的保存運算式子的字元串數組(即qlist):同一個類中的一個方法里訪問另一個方法的變數是不合理的。
——想到的三個解決方法(1已實踐成功,2,3未實踐不知是否可行):
(1)定義一個全局變數(字元串數組qlist),這樣就能在makeQ()方法中訪問該變數
——問題:數組大小是固定的,在定義數組時用戶傳的numExp(出題數量)是未知的,這時定義數組變數無法確定數組大小,只能隨便給一個足夠大的數。但這樣轉為list集合放到

String[] list2 = list.toArray(new String[list.size()]);

(2)給makeQ()定義一個返回值,返回qlist數組,check()調用返回值。
(3)由於answer.jsp中請求的目標資源是servlet中的check(),那麼把該表量從makeQ()傳到answer.jsp再傳到check().
2.將foreach迴圈內的input框輸入值傳到servlet:
——設置一個ID

<c:set var="position" value="0"/>

每迴圈一次給name賦如下值且ID+1

<input name="s${position}" id="id${position}" style="width: 60px;"/>
<c:set var="position" value="${position+1}"/>

servlet中接收:

for(int i = 0;i<expNum;i++){
    userAn[i] = request.getParameter("s"+i);
}

3.for input String:””
——一開始expNum是makeQ()方法的局部變數,無法在check()中使用——expNum也定義為全局變數
4.把兩個字元創變數userAn和correctAn用“==”來比較是否相等——字元串的比較用str1.equals(str2)

五.知識點記錄

1.JSTL

if( !MD && !Brac ){//沒有乘除法和括弧
    for (int i=0; i<expNum; i++)
        qlist[i] = question.createExp(fuNum, upper, lower);
}else if ( !MD && Brac ){//沒有乘除法有括弧
    for (int i=0; i<expNum; i++)
        qlist[i] = question.createExpWithBrac(fuNum, upper, lower);
}else if ( MD && !Brac ){//有乘除法沒有括弧
    for (int i=0; i<expNum; i++)
        qlist[i] = question.createExpWithMD(fuNum, upper, lower);
}else{//既有乘除法又有括弧
    for (int i=0; i<expNum; i++)
        qlist[i] = question.createExpWithAll(fuNum, upper, lower);
}

3.controller層包含了較多的邏輯業務處理功能,背離controller層的真正存在意義。如check()方法中涵蓋了生成計算結果,並把計算結果的存入數組的邏輯。

六.新知識新技能

我和我的結對伙伴都是主要學習後端的,關於前端編寫我們速學了一下bootstrap,用了bootstrap的基本模板,再進行修改,得到的頁面真的是整潔美觀,還具備相容性,特別好用。

七.未實現但計劃實現功能

1.錯題報告(將錯誤題目及答案列出,生成錯題集)
2.生成題目文件並課下載
3.做題歷史記錄

八.學習目標與總結

瀏覽了上屆學長學姐這個結對項目的博客,發現他們有大量的篇幅都是在做代碼性能分析,之前從來沒有接觸過,感覺可以學一學。這次涉及人機交互界面的設計,讓我意識到在進行後端技術學習時也可以抽空學學前端,能自己完成一個項目的同時,也能更好的理解前後端的交互。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 ASP.NET Core 中 繼承的是AuthorizationHandler ,而ASP.NET Framework 中繼承的是AuthorizeAttribute. 它們都是用過重寫裡面的方法實現過濾請求的。 現在我們實現如何在 ASP.NET Core MVC 實現自定義授權。 關於Au ...
  • 一、什麼是外觀模式 定義:為子系統中的一組介面提供一個一致的界面,用來訪問子系統中的一群介面。 外觀模式組成: Facade:負責子系統的的封裝調用 Subsystem Classes:具體的子系統,實現由外觀模式Facade對象來調用的具體任務 二、外觀模式的使用場景 1、設計初期階段,應該有意識 ...
  • 前言: 相信很多人都聽過一個問題:把大象關進冰箱門,需要幾步? 第一,把冰箱門打開;第二,把大象放進去;第三,把冰箱門關上。我們可以看見,這個問題的答案回答的很有步驟。接下來我們介紹一種設計模式——模板方法模式,你會發現,它與這個問題的答案實際上有很多共同之處。 一、定義 定義一個演算法骨架,允許子類 ...
  • 簡介 CAT 是一個實時和接近全量的監控系統,它側重於對Java應用的監控,基本接入了美團上海所有核心應用。目前在中間件(MVC、RPC、資料庫、緩存等)框架中得到廣泛應用,為美團各業務線提供系統的性能指標、健康狀況、監控告警等。 優勢 實時處理:信息的價值會隨時間銳減,尤其是事故處理過程中。 全量 ...
  • 想著想著結果還是過了時間! 這個月的進度堪比之前幾年! 我自己的游戲用UE4寫的風聲水起! 美術的朋友給我做了好多動作! 我都想著以後弄個個人眾籌什麼的了,可見是進展不錯! 公司的事最近不太忙,反而是結婚的事越來越忙,戒指已經買完了,50分的也算不小了,1克拉的她也嫌貴! 前倆禮拜還順便把MACOS ...
  • 好玩圖像PIL處理 一、PIL庫學習總結 1、PIL中的模塊 Image模塊、ImageChops模塊、ImageCrackCode模塊、ImageDraw模塊、ImageEnhance模塊、ImageFile模塊、ImageFileIO模塊、ImageFilter模塊、ImageFont模塊、Im ...
  • # 從決定學習編程語言到正式做出計劃擠出空餘時間,歷經一年半,因工作原因及生活原因不斷擱淺,從湖北到浙江再回湖北,暫時穩定在一家小公司,從日常加班中壓縮時間學習,於此記錄學習進度、學習問題,在此過程中望前輩們不吝指教,自己也會堅持住,希望能早日做到技術實現,在此領域不斷成長! 至此,人生苦短,我用p ...
  • 死磕 java集合之ConcurrentHashMap源碼分析(三) ConcurrentHashMap查詢是否也加鎖? ConcurrentHashMap有哪些值得我們學習的技術? ConcurrentHashMap有哪些不能解決的問題? ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...