Toggle main menu visibility
下載輕鬆架
套件下載
使用手冊
發問討論
網站地圖
:::
登入
登入
帳號
密碼
登入
:::
所有書籍
「Laravel 5.8 入門講義 」目錄
MarkDown
15-2 安裝 SweetAlert
1. 關於 Laravel
1-1 為何需要框架?
1-2 快速安裝開發環境及開發工具
1-2-1 以Laragon建立運作環境
1-2-2 修改資料庫密碼並建立myshop資料庫
1-2-3 Visual Studio Code文字編輯器
1-2-4 安裝 Composer
1-2-5 [參考]註冊 GitHub
1-2-6 [參考]瀏覽器附加元件
1-2-7 [參考]申請mailtrap帳號
1-2-8 [參考]用Homestead建構開發環境
2. 專案需求分析
2-1 建立專案
2-2 [參考]將專案加入本地端的 git
2-3 [參考]將專案放上GitHub
2-4 設定專案環境
2-5 Laravel運作週期
3. 建立使用者認證
3-1 新增中文語系
4. 了解路由 Router 及視圖 View
4-1 製作系統主樣板
4-2 為樣板製作中文語系檔
4-3 修改首頁畫面
4-4 Blade 樣板語法(自訂導覽列選項)
5. 安裝 laravel-admin 後台
5-1 修改後台設定檔
5-2 將後台選單中文化的方法
6. 修改使用者資料表
6-1 修改註冊頁面
6-2 讓新增的欄位可以寫入資料庫
6-3 剛剛我們做了什麼?
7. 開始定義系統各項功能
7-1 還沒有控制器的路由寫法
7-2 有控制器的路由寫法
8. 在後台新增買家管理
8-1 建立管理買家的後台控制器
8-2 新增管理買家的路由
8-3 新增選單
8-4 調整可修改的項目
9. 建立商品模型
9-1 編輯並執行商品(Product)的 migrate 檔案
9-2 建立後台商品管理頁面
9-3 中文化商品管理界面
9-4 後台新增商品頁面
9-5 後台的驗證表單資料
9-6 後台加入所見即所得編輯器
9-7 後台修改商品
10. 建立前台顯示商品頁面
10-1 建立前台商品控制器
10-2 修改路由讓首頁呈現商品列表
10-3 修改控制器以執行取得資料動作
10-4 修改模型以正確顯示圖片
10-5 修改視圖以顯示商品列表
11. 建立商品測試資料
11-1 讓系統也可以顯示測試圖片
11-2 建立Seeder快速填充資料
12. 建立商品詳情頁的路由
12-1 建立商品詳情頁的控制器
12-2 路由模型綁定
12-3 建立商品詳情頁的視圖
13. 一般的異常處理
13-1 優雅的異常處理
14. 關於購物車
14-1 建立購物車的模型
14-2 設定商品、購物車與買家的關聯
14-3 建立新增至購物車的路由
14-4 建立購物車控制器
15. 使用 Laravel Mix 來管理前端資源
15-1 修改前台視圖
15-2 安裝 SweetAlert
15-3 實現加入購物車按鈕
15-4 將購物項目寫入資料庫
15-5 用 fillable 批量賦值寫入
15-6 建立Request來做資料整理及檢查
15-7 利用模型觀察器建立使用者資料
15-8 根據不同情況來進行新增品項或累加品項
16. 查看購物車商品
16-1 微調購物車的傳送方式
16-2 刪除某個購物品項
16-3 調整商品數量
17. 關於訂單
17-1 建立訂單及品項的模型及控制器
17-2 設定訂單及訂單項目的關聯
17-3 加入送出訂單按鈕
17-4 我的訂單列表
17-5 後台訂單管理
17-6 中文化訂單管理界面
18. 重建由GitHub下載的Laravel專案
18-1 佈署到主機上
15-4 將購物項目寫入資料庫
Laravel 5.8 入門講義 ================= ### 一、修改首頁列表模板 1. 因為我們在列表和商品詳情頁都有「加入購物車」的按鈕,所以,我們要在兩個頁面加入相同的ajax語法。但這樣顯然不好維護,因此,我們獨立做成一個檔,然後讓不同模板來引入即可。 2. 首先開啟`\專案\resources\views\product\index.blade.php` ```markup @extends('layouts.app') @section('content')
商品一覽
@forelse($products as $product)
...略...
...略... @empty ...略... @endforelse
@endsection @section('scriptsAfterJs') @endsection ``` 3. 在第 10 行的地方,我們修改按鈕為button,並在裡面藏一個`data-id="{{ $product->id }}`資訊,放入商品編號,這樣等一下我們就可以利用 jquery 的`data()`來抓取商品變號,也就是說,當我們按這顆按鈕,系統就能知道要加入購物車的商品編號是幾號。 4. 在第 18 行的地方,我們加入一個隱藏的數量欄位,其值為1。如此才能送出數量的值。 5. 最後我們在最下方加入scriptsAfterJs的內容,簡單做出jquery的基礎呼叫動作。然後在其內容的地方。引入暫時還不存在的`product\add2cart.blade.php` ### 二、修改商品詳情頁模板 1. 接著開啟`\專案\resources\views\product\show.blade.php` ```php @extends('layouts.app') @section('title', $product->title) @section('content')
{{ $product->title }}
特價 {{ $product->price }}元
數量
件
加入購物車
{!! $product->description !!}
@endsection @section('scriptsAfterJs') @endsection ``` 2. 在第 17 行的地方,我們將數量欄位,加上`name="amount"`,和列表頁一致即可。 3. 在第 22 行的地方,我們把列表頁的加入購物車按鈕直接複製過來用即可。 4. 最後我們一樣在最下方加入scriptsAfterJs的內容,簡單做出jquery的基礎呼叫動作。然後在其內容的地方。引入暫時還不存在的`product\add2cart.blade.php` ### 三、建立共用的加入購物車語法 1. 接著建立新的視圖`\專案\resources\views\product\add2cart.blade.php` ```javascript $('.btn-add-to-cart').click(function () { console.log($(this).data('id') + ' = ' + $('input[name=amount]').val()); axios.post('{{ route('cart.store') }}', { product_id: $(this).data('id'), amount: $('input[name=amount]').val(), }) .then(function () { // 請求成功時執行: swal('加入購物車成功', '', 'success'); }, function (error) { // 請求失敗時執行: @guest swal('請先登入', '', 'error'); @endguest @auth swal('系統錯誤', '', 'error'); @endauth }) }); ``` 2. 第 2 行的地方,只是用來做檢查用的,可以利用瀏覽器的F12,來觀察我們抓到的值是否正確。 3. 第 3 行我們利用axios的post方法,將兩個變數送到路由 cart.store,以便讓控制器將使用者所選的商品編號、數量存入購物車的資料表。 - Laravel 裝好時,就有安裝axios套件了!axios 是一個基於Promise用於瀏覽器和 nodejs 的 HTTP 客戶端,簡單講,用axios 就可以用簡單的語法來進行 ajax 。 - axios 官網:
- axios 中文文件:
4. 第 10 行的 `@guest`及 14 行的`@auth`,是Laravel 5.5以後新增的條件指令,前者可以判斷是否未登入,後者則判斷是否已經登入。 5. 第 8、11、15行的 swal() 就是我們之前安裝的 SweetAlert,點下之後,就可以看到這樣的畫面: ![](https://campus-xoops.tn.edu.tw/uploads/tad_book3/image/43/pic102.png) 6. 另外,若有按F12,也可以在 Console 中看到我們用來測試抓到的編號和數量是否正確。 ![](https://campus-xoops.tn.edu.tw/uploads/tad_book3/image/43/pic103.png) [![到GitHub觀看此單元程式異動](https://campus-xoops.tn.edu.tw/uploads/tad_book3/image/34/to_github.png)](https://github.com/tad0616/myshop/commit/c97a8f377a3dd1e2701b0f697d938ae59edae5e1)
:::
書籍目錄
展開
|
闔起
快速登入
所有討論區
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
進階搜尋
計數器
今天:
昨天:
總計: