隨著 Web 技術的不斷發展,前後端分離已經成為了一種趨勢。前端框架 Vue.js 目前也越來越流行,那麼在 ThinkPHP 中如何使用 Vue 呢?本文將介紹使用 ThinkPHP5.1 框架整合 Vue.js 的方法。
一、安裝 Node.js
在開始之前,確保你已安裝 Node.js 環境,若未安裝可前往官網下載並進行安裝。
二、建立新專案
使用 Composer 指令,在終端機輸入下列指令:
composer create-project topthink/think=5.1.* myapp
執行以上指令後,會在目前路徑下產生一個 myapp 資料夾。接著執行以下進入目錄並安裝ThinkPHP 依賴:
cd myapp composer install
三、安裝前端依賴
在確認已進入myapp 目錄後,在命令列工具中輸入下列指令,安裝所需前端依賴:
npm install
安裝完成後,可在myapp 目錄下的node_modules 資料夾中,看到已成功安裝的依賴套件。
四、設定 webpack.mix.js
webpack.mix.js 檔案用於引入自訂的編譯器和前端相依性套件之間的聯繫。透過 webpack.mix.js 文件,能夠自訂如何建置和打包前端程式碼。
在myapp 專案資料夾下,建立一個新檔案webpack.mix.js,加入以下程式碼:
let mix = require('laravel-mix'); mix.js('resources/js/app.js', 'public/js') .sass('resources/sass/app.scss', 'public/css');
以上程式碼的作用是:
順便說一句,Laravel Mix 是一個將Webpack 與其他建置工具結合的工具,用於統一前端工作流程。
五、建立Vue.js 元件
在開始撰寫Vue.js 元件之前,首先需要新建一個resources/views 目錄,並在其下方新建一個資料夾index,在index 文件夾中新建一個名為vue.blade.php 的檔案。這個檔案將會是Vue.js 元件的渲染模板,程式碼如下:
<!DOCTYPE html> <html> <head> <title>Vue component - ThinkPHP</title> <meta name="csrf-token" content="{{ csrf_token() }}"> <link rel="stylesheet" href="{{ mix('css/app.css') }}" /> </head> <body> <div id="app"> <example-component></example-component> </div> <script src="{{ mix('js/app.js') }}"></script> </body> </html>
以上程式碼中:
<meta name="csrf-token" content ="{{ csrf_token() }}">
用於跨域攻擊防禦;<link rel="stylesheet" href="{{ mix('css/app .css') }}" />
引入樣式;<div id="app">
作為Vue.js 元件的容器;<example-component></example-component>
即為Vue.js 元件。 接下來在 resources/js/ 目錄下新建一個資料夾 components,並在其中新 ExampleComponent.vue 檔案。這個檔案是一個 Vue 單一檔案元件,將會被渲染到 vue.blade.php 檔案。程式碼如下:
<template> <div class="container"> <h1 class="title">Vue component - ThinkPHP</h1> <p>Message: {{ message }}</p> </div> </template> <script> export default { data () { return { message: 'Hello, Vue!' } } } </script> <style> .container { margin: 0 auto; max-width: 640px; } .title { font-size: 32px; color: #333; } </style>
以上程式碼中:
<template>
標籤用於插入HTML 範本;#< ;script>
標籤用於插入JavaScript 程式碼,透過export default 匯出Vue 單一檔案元件;<style>
標籤用於插入單一檔案元件的樣式。 六、在Blade 範本中使用Vue.js 元件
完成上述步驟後,即可在blade 範本中使用Vue.js 元件新增以下程式碼:
@extends('index.vue') @section('content') <example-component></example-component> @endsection
以上程式碼中的@extends('index.vue')
引用了剛才建立的vue.blade.php 模板, @section('content')
為Vue. js 元件指定了渲染位置,透過example-component
指定呼叫的元件名稱。
七、編譯前端程式碼
在執行以下指令進行編譯時,會自動產生 public/js/app.js 和 public/css/app.css。透過 public 目錄下的 HTML 檔案即可看到效果。
npm run dev
八、整合 Vue.js
在將 Laravel Mix 整合到 ThinkPHP 專案後,下一步就是整合 Vue.js。這裡使用了Laravel Mix 和Lodash.debounce 依賴,程式碼如下:
let mix = require('laravel-mix'); let debounce = require('lodash.debounce'); // styles mix.sass('resources/assets/sass/app.scss', 'public/css'); // scripts mix.js('resources/assets/js/app.js', 'public/js') .vue({ version: 2 }) .babel(['public/js/app.js'], 'public/js/app.js') .webpackConfig({ module: { rules: [ { test: /.vue$/, loader: 'vue-loader' } ] } }); // browserSync if (process.env.NODE_ENV !== 'production') { mix.browserSync({ proxy: process.env.APP_URL || 'localhost:8000', notify: false, files: [ 'app/**/*.php', 'resources/views/**/*.php', 'public/**/*.{css,js}' ], snippetOptions: { rule: { match: /</body>/i } } }); }
以上程式碼中:
九、準備就緒
完成以上所有步驟後,即可在 ThinkPHP 專案中順利使用 Vue.js。執行以下指令開啟本機伺服器即可看到效果:
php think run
以上是在 ThinkPHP 中使用 Vue.js 的一些方法及步驟。在此基礎上,你還可以透過更細緻的配置解決更複雜的問題,例如透過 API 傳輸資料、設定路由等等。希望以上方法能為你的實踐帶來幫助。
以上是thinkphp中如何使用vue的詳細內容。更多資訊請關注PHP中文網其他相關文章!