Toggle main menu visibility
下載輕鬆架
套件下載
使用手冊
發問討論
網站地圖
:::
登入
登入
帳號
密碼
登入
:::
所有書籍
「Laravel 5.6 入門講義」目錄
MarkDown
16-1 設定考試與測驗、考生的關聯
1. 關於 Laravel
1-1 為何需要框架?
1-2 快速安裝開發環境及開發工具
1-2-1 以XAMPP建立運作環境
1-2-2 Visual Studio Code文字編輯器
1-2-3 安裝 Composer
1-2-4 安裝 GitHub Desktop for Windows
1-2-5 [建議]瀏覽器附加元件
1-2-6 [參考]申請mailtrap帳號
1-2-7 [參考]用Homestead建構開發環境
2. 建立專案
2-1 將專案加入本地端的 git
2-2 將專案放上GitHub
2-3 設定專案環境
2-4 Laravel運作週期
3. 建立使用者認證
3-1 佈署到主機上
3-2 新增語系
3-3 開啟網站並登入
4. 了解路由的運作
4-1 製作系統主樣板
4-2 製作中文語系檔
4-3 修改首頁畫面
4-4 Blade 樣板語法
5. 安裝後台及讀寫機制
5-1 安裝後台的使用者角色管理
5-2 讓閒雜人等不能進入後台
5-3 安裝 laravel-debugbar 方便除錯
6. 建立相關資料表及模型
6-1 編輯並執行測驗(exam)的 migrate 檔案
7. 開始定義系統各項功能
7-1 還沒有控制器的路由寫法
7-2 有控制器的路由寫法
8. 建立新增測驗的操作界面
8-1 安裝marvinlabs/laravel-html-bootstrap-4套件
8-2 建立發布測驗的表單
9. 建立Exam的控制器controller
9-1 修改路由改用控制器
9-2 在視圖中取得使用者編號
9-3 將資料寫進資料庫
9-4 用 fillable 批量賦值寫入
10. 表單驗證及錯誤處理
10-1 建立Request來統一驗證
11. 讀出所有測驗
11-1 讀出時加入各種條件
11-2 加入分頁
12. 讀出單一測驗
12-1 路由模型綁定
12-2 建立並執行題目的Model 及 migrate 文件
12-3 新增題目編輯表單
12-4 儲存題目
12-5 列出題目
12-6 匯入題目
12-7 利用Model查詢資料的方法
12-8 測驗與題目的關聯
13. 利用模型工廠產生隨機題目
13-1 建立Seeder快速填充資料
14. 修改測驗
14-1 更新測驗
14-2 修改題目
14-3 更新題目
15. 刪除題目
15-1 刪除測驗
15-2 加入刪除確認
16. 建立並執行考試的Model 及 migrate 文件
16-1 設定考試與測驗、考生的關聯
16-2 產生考試界面
16-3 儲存並計分
16-4 產生考試結果
17. 安裝設定新北市OpenID登入
17-1 使用新北市OpenID登入
17-2 異動資料表
17-3 修改考試的儲存動作
18. 網站的關閉與啟動
18-1 使用路由前置字串
18-2 使用資源路由
19. 重建由GitHub下載的Laravel專案
16-3 儲存並計分
Laravel 5.6 入門講義 ================ ### 一、在控制器依據不同權限取得不同內容 1. 首先,先修改 `/專案/app/Http/Controllers/ExamController.php` 控制器,修改原本的`show()` ```php public function show(Exam $exam) { $user = Auth::user(); if ($user and $user->can('進行測驗')) { $exam->topics = $exam->topics->random(10); } return view('exam.show', compact('exam')); } ``` - 有「進行測驗」權限者: - 題目的部份,測驗本來就有設定一對多,所以,`$exam->topics`會是一個集合(`$exam`此時是`Exam`的資料物件),我們利用`random(10)`來從題目集合中,隨機取10筆來呈現。 ### 二、先簡化單一測驗的視圖 1. 修改`/專案/resources/views/exam/show.blade.php` 樣板,一樣依據權限來呈現不同畫面,不過因為程式碼越來越長,所以,我們可以把一些表單獨立成另外的視圖檔案: - 將編輯測驗的表單獨立成`\專案\resources\views\exam\form.blade.php` ```php @if(isset($topic)) {{ bs()->openForm('patch', "/topic/{$topic->id}", ['model' => $topic]) }} @else {{ bs()->openForm('post', '/topic') }} @endif {{ bs()->formGroup() ->label('題目內容', false, 'text-sm-right') ->control(bs()->textarea('topic')->placeholder('請輸入題目內容')) ->showAsRow() }} {{ bs()->formGroup() ->label('選項1', false, 'text-sm-right') ->control(bs()->text('opt1')->placeholder('輸入選項1')) ->showAsRow() }} {{ bs()->formGroup() ->label('選項2', false, 'text-sm-right') ->control(bs()->text('opt2')->placeholder('輸入選項2')) ->showAsRow() }} {{ bs()->formGroup() ->label('選項3', false, 'text-sm-right') ->control(bs()->text('opt3')->placeholder('輸入選項3')) ->showAsRow() }} {{ bs()->formGroup() ->label('選項4', false, 'text-sm-right') ->control(bs()->text('opt4')->placeholder('輸入選項4')) ->showAsRow() }} {{ bs()->formGroup() ->label('正確解答', false, 'text-sm-right') ->control(bs()->select('ans',[1=>1, 2=>2, 3=>3, 4=>4])->placeholder('請設定正確解答')) ->showAsRow() }} {{ bs()->hidden('exam_id', $exam->id) }} {{ bs()->formGroup() ->label('') ->control(bs()->submit('儲存')) ->showAsRow() }} {{ bs()->closeForm() }} ``` - 然後修改`/專案/resources/views/exam/show.blade.php` 樣板,利用`@include()`引入該檔案,位置放在`exam\form.blade.php`,引入時需寫成`exam.form` ```php @can('建立測驗') @include('exam.form') @endcan ``` - 同樣的,我們把題目的呈現也獨立成一個視圖檔案`\專案\resources\views\exam\topic.blade.php` ```php
@forelse ($exam->topics as $key => $topic)
@can('建立測驗')
刪除
編輯
({{$topic->ans}}) @endcan {{ bs()->badge()->text($key+1) }} {{$topic->topic}}
{{ bs()->radioGroup("ans[$topic->id]", [ 1=>"
❶ $topic->opt1
", 2=>"
❷ $topic->opt2
", 3=>"
❸ $topic->opt3
", 4=>"
❹ $topic->opt4
" ])->addRadioClass(['mx-3']) }}
@empty
尚無任何題目
@endforelse
``` - 再修改`/專案/resources/views/exam/show.blade.php` 樣板,一樣利用`@include()`引入該檔案,位置放在`exam\topic.blade.php`,引入時需寫成`exam.topic` ```php @include('exam.topic') ``` ### 三、在視圖中依據不同權限呈現不同內容 1. 在顯示題目的部份,如果沒有任何權限者,理論上不應該看到任何題目,所以,我們將這部份改成這樣: ```markup @if(Auth::check('建立測驗') || Auth::check('進行測驗')) @can('進行測驗') {{ bs()->openForm('post', '/test') }} @include('exam.topic') {{ bs()->hidden('user_id', Auth::id()) }} {{ bs()->hidden('exam_id', $exam->id) }}
{{ bs()->submit('寫完送出') }}
{{ bs()->closeForm() }} @else @include('exam.topic') @endcan @else @component('bs::alert', ['type' => 'info']) 共 {{ $exam->topics->count() }} 題 @endcomponent @endif ``` - 由於我們要判斷兩個以上的權限,所以,`@can`無法使用,故改用`Auth::check('建立測驗')`搭配`@if`就可以達成。 - 若是有「進行測驗」權限者,我們就替題目加上表單,讓該表單可以送出。表單送至/test即可,讓考試(test)的模型來儲存資料即可。 - 記得將測驗編號及受測者(登入者)編號放到隱藏欄位中。 使用者編號實際上也可以直接用`Auth::id()`來抓取即可。 - 至於訪客看到的訊息,我們暫時簡單的列出題目數量即可。`$exam->topics`本身是一個集合,要算數量可以用`count()` - alert視窗可以用`class="alert"`來做,也可以用`@component`的方式來做。如果只是簡單的訊息,其實用單純HTML語法來做更簡單。 2. 如:  [](https://github.com/tad0616/exam56/commit/32a23820699a817b1f0e0cdf998beaf4525d00e3)
:::
書籍目錄
展開
|
闔起
快速登入
所有討論區
Tad Search 資料查詢
Tad Booking 場地設備預約
懶人框架討論區
實戰PHP7+MySQL
XOOPS輕鬆架快速上手
校園網站輕鬆架一般討論區
Booking Helper 預約助手
es_stud_sign 班級報名
es charge 學生收費管理
E-Stud import 學生名冊管理
es_after_school 課後照顧報名
es_exam 學生作業繳交
ES_panel 校務行政面板
es_timetable 課表
ES_youtube 本校影音
info_whats 網路設備記錄
jill booking 場地預約
jill_notice 臨時公告
jill query 簡易查詢
jill receipt 領據填報
kw club 社團報名
kw device 設備借用管理系統
ntpc_oprnid 新北市 OpenID 登入
TinyD嵌入內容模組
ugm contact us 聯絡我們
ugm page 自訂頁面
ugm table 萬用表格
dummy 自訂模組
soone_submit 投稿模組
Tad Adm 站長工具箱
Tad Assignment 作業上傳展示模組
Tad Blocks 進階區塊管理
Tad Book3 線上書籍
Tad Cal 行事曆
Tad Cbox 即時留言簿
Tad Discuss 討論區模組
Tad Embed 崁入模組
Tad Evaluation 評鑑檔案管理
Tad Form 萬用表單模組
Tad FAQ 常見問答
Tad Google 相簿
Tad Gallery 電子相簿
Tad Guide 安裝精靈
Tad Honor 榮譽榜
Tad idioms 背背成語
Tad Link 好站連結
Tad Login 快速登入
Tad Lunch3 午餐資訊
Tad Lunch2 營養午餐公告
Tad Meeting 會議系統
Tad Merage 線上合併套印
Tad News 本站消息
Tad Player 影音播放
Tad RSS 友站新聞
Tad Repair 維修通報
Tad SiteMap網站地圖
Tad Timeline 重要紀事
Tad Themes 佈景管理
Tad Tools 工具包
Tad TV 直播電視
Tad Uploader 檔案上傳模組
Tad Users 大量會員管理
Tad Web 多人網頁模組
MyTabs 我的頁籤
Random Quote 隨機小語
LogCounterX 網站流量統計
Yaoh light 多區塊多層次跑馬燈模組
校園網站輕鬆架功能建議區
佈景討論區
即時留言簿
search
進階搜尋
計數器
今天:
昨天:
總計: