合併Vue和Laravel

更新於 發佈於 閱讀時間約 8 分鐘

這份指南提供了如何將 Vue.jsLaravel 進行集成的詳細步驟,並涵蓋了開發環境的設置、所需的工具、以及相關的安裝和配置方法。下面是步驟的概述與要點,對於有意使用這些技術的開發者將有很大幫助。

必要條件

  1. XAMPP(PHP 8.1 以上) - 用於提供本地開發環境。
  2. Node.js(LTS版本) - 用於支持前端的 JavaScript 工具和框架。

開發工具

  • Chrome瀏覽器,並安裝 Vue.js Devtools
  • VSCode 開發工具,建議安裝以下擴展:
    • Vue 3 Snippets
    • Inertia.js
    • Vue Language Features (Volar)

建立專案及安裝套件

1. Laravel 專案建立

composer create-project laravel/laravel:^10.* <專案名稱>

2. 安裝 PHP 套件

  • Laravel Breeze 認證套件
    composer require laravel/breeze ^1.29 --dev

  • reliese/laravel 自動生成Models套件
    composer require reliese/laravel --dev

  • PHP_CodeSniffer 程式碼規範套件
    composer require "squizlabs/php_codesniffer" --dev

  • Laravel Breeze的Vue及SSR版本
    php artisan breeze:install vue --ssr

3. 安裝 ESLint

npm init @eslint/config

選擇設置選項後,安裝 ESLint。

4. 安裝前端 JavaScript 套件

這些套件包括:

  • Vite 的 Eslint 插件
  • 無障礙檢查插件
  • 打包分析插件
  • Vue 組件自動引用插件
  • Pinia 狀態管理等
npm install vite-plugin-eslint eslint-plugin-vuejs-accessibility rollup-plugin-visualizer unplugin-vue-components unplugin-auto-import -D
npm install tailwind-merge pinia

環境設置

1. 發布配置

  • Inertia SSR 配置檔
    php artisan vendor:publish --provider="Inertia\ServiceProvider"

  • 自動生成模型配置檔
    php artisan vendor:publish --tag=reliese-models

  • 清除快取:
    php artisan config:clear

2. 修改配置文件

config/models.php

  • snake_attributes 設置為 false,以及將縮排設置為4個空格。

config/inertia.php

  • 設置 SSR 並配置 SSR 伺服器端口和開關。

.env.env.example

  • 增加 SSR 端口和開關設置。
VITE_PUSHER_SSR_PORT=13714
SSR_ENABLED=false

編輯與修改文件

vite.config.js

設定 Vue 和其他前端工具,並且引入相關插件:

import { defineConfig } from 'vite';
import laravel from 'laravel-vite-plugin';
import vue from '@vitejs/plugin-vue';
import eslintPlugin from 'vite-plugin-eslint';
import AutoImport from 'unplugin-auto-import/vite';
import Components from 'unplugin-vue-components/vite';

export default defineConfig({
plugins: [
laravel({ input: 'resources/js/app.js', ssr: 'resources/js/ssr.js', refresh: true }),
vue(),
eslintPlugin(),
AutoImport({
imports: ['vue'],
dirs: ['resources/js/Store/**'],
vueTemplate: true,
eslintrc: { enabled: true },
}),
Components({ dirs: ['resources/js/Components'] }),
],
});

app.jsssr.js

resources/js/app.jsresources/js/ssr.js 中進行設置,特別是引入了 Pinia 狀態管理,並設置了布局。

Laravel 中新增 PHP 共用函數

app/Http/Helpers.php 中加入固定格式的回應函數:

function rtFormat($data = [], $code = 1, $message = '執行成功')
{
$status = [0, 1];
if (!is_int($code) || !in_array($code, $status) || !is_string($message)) {
throw new Exception('rt_format函式傳入參數錯誤');
}

$format = (object)[
'rt_code' => $code,
'rt_message' => $message,
'rt_data' => $data,
];

return $format;
}

單元測試

修改 phpunit.xml,設置相關選項,例如停止在失敗或錯誤時的繼續測試:

<phpunit stopOnFailure="true" stopOnError="true">
<php>
<env name="DB_DATABASE" value="test"/>
</php>
</phpunit>

結語

這份指南詳細描述了如何設置與配置 Vue.js 和 Laravel 的集成專案,並且提供了相關套件安裝、配置文件修改的步驟。對於希望結合前後端技術的開發者,這些步驟可以幫助迅速搭建開發環境。接下來會介紹Laravel 合併應用。


對於這類的撰寫方式習慣嗎?歡迎多多進行良性的知識交流喔!目前是在學習階段,大家有不同看法的話歡迎進行良性的知識交流!

 

大家可以考慮多多分享文章和考慮訂閱沙龍方案或贊助等喔!不過請注意不要違反著作權等行為。當然決定權都在於您,不會干涉您的任何決定。

 

提醒,文章僅供正當的知識參考,文章不負任何責任。

留言
avatar-img
留言分享你的想法!
avatar-img
阿棋的沙龍
2會員
34內容數
有軟體開發相關文章。
阿棋的沙龍的其他內容
2025/02/19
在現代的Web應用中,發送即時郵件通知是一項常見的需求。無論是訂單狀態更新、賬單付款通知,還是帳號活動警報,這些通知都能讓用戶即時了解重要信息,並提升使用者體驗。今天,將介紹如何在Laravel中實現一個簡單的郵件通知系統,並演示如何使用通知來通知使用者。
2025/02/19
在現代的Web應用中,發送即時郵件通知是一項常見的需求。無論是訂單狀態更新、賬單付款通知,還是帳號活動警報,這些通知都能讓用戶即時了解重要信息,並提升使用者體驗。今天,將介紹如何在Laravel中實現一個簡單的郵件通知系統,並演示如何使用通知來通知使用者。
2025/02/12
網站的安全性對於保護用戶資料和防止惡意攻擊至關重要。對於許多應用來說,實現Email驗證和兩步驟驗證(2FA)是增強用戶安全的一種有效方式。今天將探索如何在Laravel框架中實現這兩項功能,並結合Google Gmail的應用程式密碼,從而保障你網站的用戶帳號安全。
2025/02/12
網站的安全性對於保護用戶資料和防止惡意攻擊至關重要。對於許多應用來說,實現Email驗證和兩步驟驗證(2FA)是增強用戶安全的一種有效方式。今天將探索如何在Laravel框架中實現這兩項功能,並結合Google Gmail的應用程式密碼,從而保障你網站的用戶帳號安全。
2025/02/05
在現代網絡安全環境中,網站的安全性至關重要。為了確保你的網站免受各種攻擊,進行網站弱點掃描是不可或缺的一步。今天,將介紹一個強大且免費的網站安全掃描工具——OWASP ZAP(Zed Attack Proxy),它不僅功能強大,且易於使用,適合各種用戶,無論你是初學者還是資深的安全專家。
2025/02/05
在現代網絡安全環境中,網站的安全性至關重要。為了確保你的網站免受各種攻擊,進行網站弱點掃描是不可或缺的一步。今天,將介紹一個強大且免費的網站安全掃描工具——OWASP ZAP(Zed Attack Proxy),它不僅功能強大,且易於使用,適合各種用戶,無論你是初學者還是資深的安全專家。
看更多
你可能也想看
Thumbnail
「欸!這是在哪裡買的?求連結 🥺」 誰叫你太有品味,一發就讓大家跟著剁手手? 讓你回購再回購的生活好物,是時候該介紹出場了吧! 「開箱你的美好生活」現正召喚各路好物的開箱使者 🤩
Thumbnail
「欸!這是在哪裡買的?求連結 🥺」 誰叫你太有品味,一發就讓大家跟著剁手手? 讓你回購再回購的生活好物,是時候該介紹出場了吧! 「開箱你的美好生活」現正召喚各路好物的開箱使者 🤩
Thumbnail
在這篇文章中,我們將討論如何在 Vue 應用中使用路由、GitHub Pages 部署以及狀態管理工具 Pinia。這些概念在開發上通常會使用到,讓我們一步一步深入這些重要的概念!
Thumbnail
在這篇文章中,我們將討論如何在 Vue 應用中使用路由、GitHub Pages 部署以及狀態管理工具 Pinia。這些概念在開發上通常會使用到,讓我們一步一步深入這些重要的概念!
Thumbnail
在這篇文章中,我們將介紹如何快速建置一個 Vue 專案,並涵蓋一些基本的檔案結構和組件使用的方式。希望能幫助你順利開始 Vue 的開發之旅!
Thumbnail
在這篇文章中,我們將介紹如何快速建置一個 Vue 專案,並涵蓋一些基本的檔案結構和組件使用的方式。希望能幫助你順利開始 Vue 的開發之旅!
Thumbnail
Laravel是一個以MVC(參考:[設計模式]MVC)為架構的PHP Web框架。Laravel支援使用者身份驗證和授權,提供模組化套件系統。Laravel使用Blade模板系統將PHP程式碼與HTML網頁分離。 安裝環境 下載安裝composer https://getcomposer.o
Thumbnail
Laravel是一個以MVC(參考:[設計模式]MVC)為架構的PHP Web框架。Laravel支援使用者身份驗證和授權,提供模組化套件系統。Laravel使用Blade模板系統將PHP程式碼與HTML網頁分離。 安裝環境 下載安裝composer https://getcomposer.o
Thumbnail
Vue3 學習筆記,vue-router 篇。
Thumbnail
Vue3 學習筆記,vue-router 篇。
Thumbnail
Vue3 學習筆記,專案建立與基礎響應式篇
Thumbnail
Vue3 學習筆記,專案建立與基礎響應式篇
Thumbnail
本篇純粹紀錄實作流程,以方便未來可以照此版繼續優化改進作法,這篇會使用Laravel 9版本並搭配Boostrap 5來做開發。 發現將每一次的實作作筆記,回頭再看的時候,就可以發現實作差異並進行改正,沒搞懂的底層操作也能在覆盤的時候理解,建議大家都要筆記自己的實作流程。
Thumbnail
本篇純粹紀錄實作流程,以方便未來可以照此版繼續優化改進作法,這篇會使用Laravel 9版本並搭配Boostrap 5來做開發。 發現將每一次的實作作筆記,回頭再看的時候,就可以發現實作差異並進行改正,沒搞懂的底層操作也能在覆盤的時候理解,建議大家都要筆記自己的實作流程。
Thumbnail
作為一個純後端,不會前端也是正常的事(誤),但該練習的技能線還是得每天練習一點,尤其我是一個前端小廢物,那既然要用Laravel 9 版本來做開發,那就得先試試看vite這個新的工具,基本上這邊就簡單介紹使用方式,另一篇在額外說明Laravel Mix 與 Vite 差別。
Thumbnail
作為一個純後端,不會前端也是正常的事(誤),但該練習的技能線還是得每天練習一點,尤其我是一個前端小廢物,那既然要用Laravel 9 版本來做開發,那就得先試試看vite這個新的工具,基本上這邊就簡單介紹使用方式,另一篇在額外說明Laravel Mix 與 Vite 差別。
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News