來架個網站吧-14.網站開發-4-MVC-1-view

2024-02-28 來架個網站吧 linux 2023 iThome 鐵人賽 Grails

來架個網站吧-14.網站開發-4-MVC-1-view

tags: 來架個網站吧 Grails

我是目錄


想了又想,決定還是從畫面開始講起,雖然跟我自己的開發習慣不一樣。因為在我自己學習網站開發的階段是從畫面開始學習,也許這樣對初學者會比較容易上手。後來工作三、四年之後,逐漸會先把系統的資料處理流程先構築完畢,接下來在處理使用者或是API介面部份,最後在修整程式細節。

今天主要是把網站畫面構築出來,這邊我主要使用的技術如下:

  • bootstrap v4
  • bootstrap-table
  • jQuery

新增 Controller

在新增畫面之前,首先新增一個Controller。一個Controller代表ContextPath後的第一個Path。而第二個Path代表Controller裡的Action。

day-14-1-新增Controller-0

接下來就用IDEA完成新增DictController.groovy

  • grails-app/controllers/dict/DictController.groovy

day-14-1-新增Controller-1

  1. Controllers資料夾中按下右鍵
  2. 選擇新增Grails Controller

day-14-1-新增Controller-2

  1. 輸入要新增的Controller,這次是: DictController
  2. 新增成功後就會在Controllers下中建立一個DictController.groovy檔案。

新增 laylout:

在新增一個view之前,建議先完成一個layout(母板),以下是這次是要要新增 layout 所需要的檔案。

  • stylesheet: grails-app/assets/stylesheets/dict-main.css
  • javascript: grails-app/assets/javascripts/dict-main.js
  • laylout: grails-app/views/layouts/dict-main.gsp

目錄結構如下

grails-app
    ├── assets
    │   ├── javascripts
    │   │   ├── bootstrap.js
    │   │   ├── bootstrap.js.map
    │   │   ├── bootstrap.min.js
    │   │   ├── bootstrap.min.js.map
    │   │   ├── dict-main.js
    │   │   ├── jquery-3.5.1.js
    │   │   ├── jquery-3.5.1.min.js
    │   │   ├── jquery-3.5.1.min.js.map
    │   │   ├── popper.js
    │   │   ├── popper.min.js
    │   │   └── popper.min.js.map
    │   └── stylesheets
    │       ├── bootstrap.css
    │       ├── bootstrap.css.map
    │       ├── bootstrap.min.css
    │       ├── bootstrap.min.css.map
    │       └── dict-main.css
    └── views
        ├── dict
        │   └── index.gsp
        └── layouts
            └── dict-main.gsp

grails-app/assets/stylesheets/dict-main.css

這個檔案是放置 css文件內容。

/*
*= require bootstrap
*= require_self
*/

grails-app/assets/javascripts/dict-main.js

這個檔案是放置 javascript 文件內容。

//= require jquery-3.5.1.min
//= require popper.min
//= require bootstrap
//= require_self

grails-app/views/layouts/dict-main.gsp

處理好 grails-app/assets/javascripts/dict-main.jsgrails-app/assets/stylesheets/dict-main.css 之後,接下來是製作layout。

在這邊有用到一項技術: Sitemesh

系統流程大概是將gsp發送給使用者之前,透過攔截器處理裝修後將母板套入制GSP後再發送給使用者。

<%--
  Created by IntelliJ IDEA.
  User: pollochang
  Date: 9/25/23
  Time: 11:10 AM
--%>

<%@ page contentType="text/html;charset=UTF-8" %>
<html>
<head>
    <title>鐵人字典</title>
    <asset:stylesheet src="dict-main.css"/>
    <asset:javascript src="dict-main.js"/>
    <g:layoutHead/>
</head>

<body>
    <g:layoutBody/>
</body>
</html>

新增 view: grails-app/views/dict/index.gsp

處理完成GSP的 layout 之後,接下來就是新增每支action對應的view了。沒有特別指名render 路徑,預設都會在 grails-app/view/[controller-name]/[action-name]

day-14-2-新增view-1

  1. views/dict資料夾中按下右鍵。
  2. 選擇新增GSP

day-14-2-新增view-2

  1. 輸入要新增的gsp檔案名稱。

index.gsp 內容如下:

<%--
  Created by IntelliJ IDEA.
  User: pollochang
  Date: 9/25/23
  Time: 11:05 AM
--%>

<%@ page contentType="text/html;charset=UTF-8" %>
<html>
<head>
    <meta name="layout" content="dict-main"/>
    <link href="https://unpkg.com/[email protected]/dist/bootstrap-table.min.css" rel="stylesheet">

    <script src="https://unpkg.com/[email protected]/dist/bootstrap-table.min.js"></script>
</head>

<body>
<div class="container">
    <div class="row">
        <div class="col">
            <div class="form-group input-group">
                <h3><label for="searchWord">請輸入查詢的詞彙</label></h3>
                <div class="input-group mb-3">
                    <g:textField id="searchWord" name="searchWord" class="form-control" aria-describedby="searchWordHelp" />
                    <div class="input-group-append">
                    <g:submitButton id="searchButton" name="searchButton" value="查詢" class="btn btn-outline-primary" type="button" />
                    </div>
                </div>
                <small id="searchWordHelp" class="form-text text-muted">嘗試輸入: 天</small>
            </div>
        </div>
    </div>
    <div class="row">
        <div class="col">
            <h3>查詢結果</h3>
        </div>
    </div>
    <div class="row">
        <div class="col">

            <table
                    data-toggle="table"
                    data-search="false"
                    data-show-columns="false">
                <thead>
                <tr class="tr-class">
                    <th data-field="word" data-valign="middle">單字(注音)</th>
                    <th data-field="radical" data-valign="middle">部首</th>
                    <th data-field="totalStrokes" data-valign="middle">總筆畫數/部首外筆畫</th>
                    <th data-field="explanation" data-valign="middle">解釋</th>
                </tr>
                </thead>
                <tbody>
                <tr>
                    <td>
                        一(一)
                    </td>
                    <td>
                    </td>
                    <td>
                        1/0
                    </td>
                    <td>
                        (1) 自ㄗˋ然ㄖㄢˊ數ㄕㄨˋ的˙ㄉㄜ第ㄉㄧˋ一ㄧ位ㄨㄟˋ。大ㄉㄚˋ寫ㄒㄧㄝˇ作ㄗㄨㄛˋ「壹ㄧ」,阿ㄚ拉ㄌㄚ伯ㄅㄛˊ數ㄕㄨˋ字ㄗˋ作ㄗㄨㄛˋ「1」。
                        (2)單ㄉㄢ個˙ㄍㄜ、不ㄅㄨˊ是ㄕˋ多ㄉㄨㄛ數ㄕㄨˋ的˙ㄉㄜ。如ㄖㄨˊ:「一ㄧˊ個˙ㄍㄜ」、「一ㄧˋ張ㄓㄤ紙ㄓˇ」。
                        (3) 相ㄒㄧㄤ同ㄊㄨㄥˊ、一ㄧˊ致ㄓˋ。如ㄖㄨˊ:「一ㄧˋ模ㄇㄛˊ一ㄧˊ樣ㄧㄤˋ」、「大ㄉㄚˋ小ㄒㄧㄠˇ不ㄅㄨˋ一ㄧ」。
                        (4) 專ㄓㄨㄢ注ㄓㄨˋ、純ㄔㄨㄣˊ正ㄓㄥˋ。如ㄖㄨˊ:「一ㄧˋ心ㄒㄧㄣ一ㄧˊ意ㄧˋ」、「用ㄩㄥˋ情ㄑㄧㄥˊ專ㄓㄨㄢ一ㄧ」。
                        (5)全ㄑㄩㄢˊ、整ㄓㄥˇ。如ㄖㄨˊ:「一ㄧˋ身ㄕㄣ臭ㄔㄡˋ汗ㄏㄢˋ」、「一ㄧˋ生ㄕㄥ一ㄧˊ世ㄕˋ」。
                        (6) 每ㄇㄟˇ。如ㄖㄨˊ:「一ㄧˋ班ㄅㄢ四ㄙˋ十ㄕˊ人ㄖㄣˊ」、「一ㄧˊ頁ㄧㄝˋ六ㄌㄧㄡˋ百ㄅㄞˇ字ㄗˋ」。
                        (7) 才ㄘㄞˊ、剛ㄍㄤ剛ㄍㄤ。如ㄖㄨˊ:「一ㄧˋ聽ㄊㄧㄥ就ㄐㄧㄡˋ懂ㄉㄨㄥˇ」、「天ㄊㄧㄢ一ㄧˊ亮ㄌㄧㄤˋ,他ㄊㄚ便ㄅㄧㄢˋ起ㄑㄧˇ床ㄔㄨㄤˊ。」
                        (8)放ㄈㄤˋ在ㄗㄞˋ兩ㄌㄧㄤˇ重ㄔㄨㄥˊ疊ㄉㄧㄝˊ的˙ㄉㄜ動ㄉㄨㄥˋ詞ㄘˊ之ㄓ間ㄐㄧㄢ,表ㄅㄧㄠˇ示ㄕˋ短ㄉㄨㄢˇ暫ㄓㄢˋ或ㄏㄨㄛˋ略ㄌㄩㄝˋ微ㄨㄟˊ嘗ㄔㄤˊ試ㄕˋ的˙ㄉㄜ意ㄧˋ思˙ㄙ。如ㄖㄨˊ:「動ㄉㄨㄥˋ一ㄧ動ㄉㄨㄥˋ」、「問ㄨㄣˋ一ㄧ問ㄨㄣˋ」、「聞ㄨㄣˊ一ㄧ聞ㄨㄣˊ」。
                        (9) 另ㄌㄧㄥˋ外ㄨㄞˋ的˙ㄉㄜ。如ㄖㄨˊ:「蟬ㄔㄢˊ,一ㄧˋ名ㄇㄧㄥˊ知ㄓ了ㄌㄧㄠˇ。」
                        (10)一ㄧˊ旦ㄉㄢˋ。表ㄅㄧㄠˇ示ㄕˋ假ㄐㄧㄚˇ設ㄕㄜˋ的˙ㄉㄜ語ㄩˇ氣ㄑㄧˋ。如ㄖㄨˊ:「一ㄧˋ失ㄕ足ㄗㄨˊ成ㄔㄥˊ千ㄑㄧㄢ古ㄍㄨˇ恨ㄏㄣˋ」。
                    </td>
                </tr>
                </tbody>
            </table>
        </div>
    </div>
</div>
</body>
</html>

檢視成果

  • 測試連結: http://localhost:8099/dict/index

day-14-finish

參考資料

SiteMesh