作者johnny94 (32767)
看板java
標題[問題] 關於一個設計的問題
時間Mon Jun 19 23:15:57 2017
目前工作是使用 Spring boot + thymeleaf 在開發,最近遇到了一個設計上的問題,
做事做出來了,但是總覺得有更好的辦法,因此上來請益一下。
需求大致上是一個可以讓使用者寫文章,後台有評審可以評論。
後台的使用流程是這樣的:
1. 評審登入後台
2. 進入到評論文章的畫面,列出一串文章的內容及作者,以及 textaera 讓評審寫評論
2.a 如果評審有寫過評論的話,則 textarea 顯示之前寫的內容
3.寫完後按下「確認鈕」進入確認畫面,畫面跟「2」基本上一樣一樣,只是 textarea
換成其他的HTML元素顯示評審輸入的內容。
-----------------------------------------------------------------------------
以下說明我使用的方式以及遇到的疑惑點:
在 2 這個畫面,我寫了一個 class 長這樣
class ArticleDto
long articleId // 文章ID
String article // 文章內容
String autohr // 作者
String comment // 評審的評論
下 SQL 後把取得的資料轉換成 Map<Long, ArticleDto> ,並在畫面中顯示出來
其中 Long 放的是文章的 ID,這個 ID 其實就是跟 ArticleDto 裡的 articleId
是一樣的東西。
同樣在 2 這個畫面,有一個 form 的類別長這樣,用來保存 POST 表單後的資料:
class CommentForm
long articleId // 文章ID
String comment // 評審的評論
為了能夠在 3 這個確認畫面同時顯示顯示出文章的內容以及評審的評論,
當使用者 POST 表單之後,我必須在 controller 裡面用類似這種方式:
// 用 articleId 找出評審的評論是對應哪篇文章
// 找到後把評審輸入的評論設為對該篇文章的評論
articleMap.get(form.articleId).setComment(form.comment)
把評審輸入的評論,跟 Map 裡面的內容組合起來,才有辦法在 3 這個確認畫面
同時顯示文章相關資以及評審的評論。這也是為什麼我的 CommentForm
跟 Map 的 key 都是 articleId。
-----------------------------------------------------------------------
雖然是做出來了,但是總感覺有更好的方式可以做出這個功能,
不知道有沒有相關的經驗可以讓我參考一下。
我已經盡量把最重要的資訊呈現出來,如果還有看不懂的部分,
歡迎提問我再補充,謝謝各位。
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 153.150.177.210
※ 文章網址: https://www.ptt.cc/bbs/java/M.1497885361.A.C83.html
※ 編輯: johnny94 (153.150.177.210), 06/19/2017 23:16:38
推 mozzan: 用Map意義在哪?你有用db嗎 06/20 22:22
→ ssccg: 你在2的輸入、確認是單一筆文章? 所以form資料只有一個id? 06/20 22:53
→ ssccg: 那為什麼3的畫面還是需要列出所有文章? 06/20 22:54
→ ssccg: 2、3畫面都要全部文章的話,這設計沒什麼問題 06/20 22:56
→ ssccg: 但是2、3畫面都全部文章,卻沒有要支援一次寫多筆感覺很怪 06/20 22:57
→ pttworld: 4.或3.結束才對article寫入。確認之前可反悔多次。 06/21 20:15