Toggle main menu visibility
下載輕鬆架
套件下載
使用手冊
發問討論
網站地圖
:::
登入
登入
帳號
密碼
登入
:::
所有書籍
「Laravel 5.6 入門講義」目錄
MarkDown
13-1 建立Seeder快速填充資料
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專案
14-1 更新測驗
Laravel 5.6 入門講義 ================ ### 一、修改樣板,加入編輯按鈕 1. 修改原來的 `/專案/resources/views/exam/show.blade.php` 樣板,加入編輯按鈕: ```php
{{$exam->title}} @can('建立測驗')
編輯
@endcan
``` 2. 我們必須根據不同權限顯示不同功能,老師和學生在進入測驗的畫面時,應該要看到不同功能,老師應該是要進行題目管理,學生則是進行測驗。利用`@can()`就可以判斷不同身份。 3. 詳情請看:
### 二、修改路由 1. 修改路由` /專案/routes/web.php` 加入 `edit `的路由,`{exam}` 放在前後其實都沒關係。 ```php Route::get('/exam/{exam}/edit', 'ExamController@edit')->name('exam.edit'); ``` ### 三、修改控制器(用同一個視圖) 1. 修改的界面主要就是讀出原始內容,然後塞到原來的建立標單裡,也就是套用到`exam/create.blade.php`的表單中。這裡我們不另外做edit.blade.php用來編輯的視圖,因為編輯和建立的視圖其實90%以上都一樣,弄個兩套維護起來比較不易(容易改了A卻忘了B),所以,我們來看一下用同一個視圖,需要注意哪些事? - 建立的http動詞是`post`,修改則是`patch`(如此,會自動加上CSRF保護,避免跨站攻擊) - 建立的表單`action`是`/exam`,修改則是`/exam/編號` - 建立時,啟用欄位(enable)預設值為1,修改時,則是視實際情況 2. 所以,根據以上,我們在控制器中 `/專案/app/Http/Controllers/ExamController.php`,先加入 `edit `的方法: ```php public function edit(Exam $exam) { return view('exam.create', compact('exam')); } ``` - `$exam`是一筆完整Exam資料,`$exam->id`就是該資料的編號 3. 最後,修改 `/專案/resources/views/exam/create.blade.php` 樣板: ```markup @extends('layouts.app') @section('content')
{{ __('Create Exam') }}
@can('建立測驗') @if(isset($exam)) {{ bs()->openForm('patch', "/exam/{$exam->id}" , [ 'model' => $exam]) }} @else {{ bs()->openForm('post', '/exam') }} @endif {{ bs()->formGroup() ->label('測驗標題', false, 'text-sm-right') ->control(bs()->text('title')->placeholder('請填入測驗標題')) ->showAsRow() }} {{ bs()->formGroup() ->label('測驗狀態', false, 'text-sm-right') ->control(bs()->radioGroup('enable', [1 => '啟用', 0 => '關閉']) ->selectedOption(isset($exam)?$exam->enable:1) ->inline()) ->showAsRow() }} {{ bs()->hidden('user_id', Auth::id()) }} {{ bs()->formGroup() ->label('') ->control(bs()->submit('建立測驗')) ->showAsRow() }} {{ bs()->closeForm() }} @if (count($errors) > 0) @component('bs::alert', ['type' => 'danger'])
@foreach ($errors->all() as $error)
{{ $error }}
@endforeach
@endcomponent @endif @else @component('bs::alert', ['type' => 'danger']) @slot('heading') 無建立測驗的權限 @endslot @endcomponent @endcan @endsection ``` - 第5行的地方,我們判斷有無傳進 $exam 物件,來決定是要新增還是修改? - 第6行的地方,當有測驗編號,那就是修改,http動詞我們改用`patch`。`action`路徑也不同,加入測驗編號`$exam->id`。此外,多了`['model' => $exam]`,也就是此表單要套用預設值。 - 18行用三元一次寫法,判斷有物件時才使用物件值,沒有就給1 4. 看起來像這樣: ![](https://campus-xoops.tn.edu.tw/uploads/tad_book3/image/37/l56_050.png) 5. 最後,只要完成「更新」部份的功能即可。 ### 三、讓被關閉的測驗也能顯示出來 1. 在修改的過程中發現,被關閉的測驗將不會被列出,故也無法修改,所以,我們需要調整一下,改成若是有「建立測驗」權限者,就可以看到被關閉測驗,若沒有,則不秀出。 2. 所以,我們先修改控制器`/專案/app/Http/Controllers/ExamController.php`,編輯 `index`的方法: ```php public function index() { $user = Auth::user(); if ($user and $user->can('建立測驗')) { $exams = Exam::orderBy('created_at', 'desc') ->paginate(3); } else { $exams = Exam::where('enable', 1) ->orderBy('created_at', 'desc') ->paginate(2); } return view('exam.index', compact('exams')); } ``` 1. 主要是先取得使用者資料,此時,上方需告知要使用`Illuminate\Support\Facades\Auth`才行 ```php use Illuminate\Support\Facades\Auth; ``` 2. 接著判斷有無$user物件(沒登入者不會有),若有,判斷有無權限。 3. 有權限者就不加上`where('enable', 1)`這個條件(顯示數也可以調多一點) 3. 接著修改`\專案\resources\views\exam\index.blade.php`,加入判斷,若`$exam->enable`不等於1,就顯示一個關閉的徽章 ```markup @extends('layouts.app') @section('content')
測驗一覽
(共 {{$exams->total()}} 筆資料)
@forelse ($exams as $exam)
@if($exam->enable!=1) {{ bs()->badge()->text('關閉') }} @endif {{$exam->created_at->format("Y年m月d日") }} -
{{$exam->title}}
@empty
尚無任何測驗
@endforelse
{{ $exams->links() }}
@endsection ``` 4. 看起來就像這樣: ![](https://campus-xoops.tn.edu.tw/uploads/tad_book3/image/37/l56_051.png) [![到GitHub觀看此單元程式異動](https://campus-xoops.tn.edu.tw/uploads/tad_book3/image/34/to_github.png)](https://github.com/tad0616/exam56/commit/7d1bea860e55a42b32301f4e0287d2726623a6f8)
:::
書籍目錄
展開
|
闔起
快速登入
所有討論區
Tad Search 資料查詢
懶人框架討論區
實戰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 萬用表格
Yaoh Servicelearning 服務學習管理系統
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
進階搜尋
計數器
今天:
昨天:
總計: