Laravel + Vue 3(Vite、TypeScript)SPA 設(shè)置

2023-1-28    前端達(dá)人

在本教程中,我將向大家展示如何使用 Laravel + Vue 3 使用 typescript 和 Vite 設(shè)置你自己的單頁應(yīng)用程序。

這是在 Laravel 項目中添加 PWA 的手動方法。我們不會使用 InertiaJS 或其他類似的東西,我們也不會混合使用。我們將手動實現(xiàn)我們自己的 VueJS 前端。

第 1 步:讓我們創(chuàng)建我們的 Laravel 項目

composer create-project laravel/laravel laravel-vue-manual 
  • 1

第 2 步:設(shè)置前端

在我們的 laravel 項目中,讓我們使用 yarn 運(yùn)行一個命令,并選擇 vue 和 typescript

yarn create vite 
  • 1

將項目名稱設(shè)置為:FrontEndApp
選擇:Vue
選擇:TypeScript

然后轉(zhuǎn)到我們的FrontEndApp目錄并運(yùn)行yarn或yarn install安裝依賴項。

配置 Vite

讓我們配置我們的 vite 配置FrontEndApp\vite.config.ts

import { defineConfig } from "vite"; import vue from "@vitejs/plugin-vue"; export default ({ mode }) => { // 檢查是否開發(fā) const isDevelopment = mode === "development"; return defineConfig({ server: { port: 3000, }, build: { // 生成的文件將添加到此處 outDir: "./../public/app", }, // 也將更改基于模式的基礎(chǔ) base: isDevelopment ? "/" : "/app/", plugins: [vue()], }); }; 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

然后讓我們更改build腳本FrontEndApp\package.json,這樣每次我們構(gòu)建它時都會替換以下文件public/app:

{ ... "scripts": { "dev": "vite", "build": "vue-tsc --noEmit && vite build --emptyOutDir", "preview": "vite preview" }, ... } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

現(xiàn)在,如果我們在FrontEndApp中運(yùn)行yarn build,它應(yīng)該在laravel項目的根目錄中的public文件夾中創(chuàng)建一個名為 app 的文件夾。

在這里插入圖片描述

第 3 步:設(shè)置 Laravel 路由

讓我們設(shè)置我們的 laravel 路由,以便我們可以訪問我們剛剛創(chuàng)建的文件。

讓我們編輯這個文件 routes\web.php

<?php

use Illuminate\Support\Facades\Route; Route::get('/', function () { return view('welcome'); }); Route::get('/app/{any}', function () { $path = public_path('app/index.html'); abort_unless(file_exists($path), 400, 'Page is not Found!'); return file_get_contents($path); }) ->name('FrontEndApp'); 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

現(xiàn)在,如果我們http://127.0.0.1:8000/app在瀏覽器中打開,我們現(xiàn)在可以看到我們的應(yīng)用程序已啟動。

第 4 步:設(shè)置腳本

我們將在我們的根項目目錄中添加一個開發(fā)包,并同時調(diào)用它。我們用它來一次運(yùn)行 2 個或更多命令。

安裝:

yarn add -D concurrently 
  • 1

如果我們想要自動工作,不想每次使用時都重新構(gòu)建frontednapp,我們要做的是在package.json項目的根目錄中添加一個新腳本。

{ ... "scripts": { ... "front:serve": "cd FrontEndApp && yarn dev", "front:build": "cd FrontEndApp && yarn build", "serve": "concurrently \"php artisan serve --port=8080\" \"yarn front:serve\"", "deploy": "yarn setup && yarn front:build && php artisan migrate" }, ... } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

這樣, running yarn serve將同時運(yùn)行 127.0.0.1:8080 和 localhost:3000。你現(xiàn)在可以同時使用這兩個項目。

完成 FrontEndApp 的工作后,你可以運(yùn)行 yarn deploy 以構(gòu)建我們的前端。

結(jié)論

我相信這也是大家可以在 laravel 項目中添加 pwa 的一種方式,這樣你就可以將它們保存在一個項目中。

考慮到這一點(diǎn),你可以添加routes到你的 FrontEndApp 項目中,還可以添加狀態(tài)管理器PiniaJA,例如 等等。




文章來源:csdn

著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。

藍(lán)藍(lán)設(shè)計建立了UI設(shè)計分享群,每天會分享國內(nèi)外的一些優(yōu)秀設(shè)計,如果有興趣的話,可以進(jìn)入一起成長學(xué)習(xí),請加藍(lán)小助,微信號:ben_lanlan,報下信息,藍(lán)小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務(wù)合作,也請與我們聯(lián)系01063334945。


分享此文一切功德,皆悉回向給文章原作者及眾讀者.
免責(zé)聲明:藍(lán)藍(lán)設(shè)計尊重原作者,文章的版權(quán)歸原作者。如涉及版權(quán)問題,請及時與我們?nèi)〉寐?lián)系,我們立即更正或刪除。


藍(lán)藍(lán)設(shè)計sillybuy.com )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標(biāo)定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 平面設(shè)計服務(wù)、UI設(shè)計公司、界面設(shè)計公司、UI設(shè)計服務(wù)公司、數(shù)據(jù)可視化設(shè)計公司、UI交互設(shè)計公司、高端網(wǎng)站設(shè)計公司、UI咨詢、用戶體驗公司、軟件界面設(shè)計公司

日歷

鏈接

個人資料

存檔