Dengan pembangunan berterusan teknologi web, pemisahan bahagian hadapan dan belakang telah menjadi satu trend. Rangka kerja bahagian hadapan Vue.js semakin popular sekarang, jadi bagaimana untuk menggunakan Vue dalam ThinkPHP? Artikel ini akan memperkenalkan cara mengintegrasikan Vue.js menggunakan rangka kerja ThinkPHP5.1.
1. Pasang Node.js
Sebelum anda mula, pastikan anda telah memasang persekitaran Node.js, anda boleh pergi ke tapak web rasmi untuk memuat turun dan memasangnya.
2. Cipta projek baharu
Gunakan arahan Komposer dan masukkan arahan berikut dalam terminal:
composer create-project topthink/think=5.1.* myapp
Selepas menjalankan arahan di atas, folder myapp akan dihasilkan dalam laluan semasa. Kemudian jalankan yang berikut untuk memasuki direktori dan memasang kebergantungan ThinkPHP:
cd myapp composer install
3. Pasang kebergantungan bahagian hadapan
Selepas mengesahkan bahawa anda telah memasuki direktori myapp, masukkan arahan berikut dalam arahan alat baris untuk memasang kebergantungan bahagian hadapan yang diperlukan :
npm install
Selepas pemasangan selesai, anda boleh melihat pakej kebergantungan yang berjaya dipasang dalam folder node_modules di bawah direktori myapp.
4. Konfigurasi webpack.mix.js
Fail webpack.mix.js digunakan untuk memperkenalkan sambungan antara pengkompil tersuai dan pakej kebergantungan bahagian hadapan. Melalui fail webpack.mix.js, anda boleh menyesuaikan cara kod bahagian hadapan dibina dan dibungkus.
Dalam folder projek myapp, cipta fail baharu webpack.mix.js dan tambah kod berikut:
let mix = require('laravel-mix'); mix.js('resources/js/app.js', 'public/js') .sass('resources/sass/app.scss', 'public/css');
Fungsi kod di atas ialah:
Sebenarnya, Laravel Mix ialah alat yang menggabungkan Webpack dengan alatan binaan lain untuk menyatukan aliran kerja bahagian hadapan.
5. Cipta komponen Vue.js
Sebelum mula menulis komponen Vue.js, anda perlu mencipta direktori sumber/pandangan dan mencipta indeks folder baharu di bawahnya, dalam fail indeks Cipta fail baharu bernama vue.blade.php dalam folder. Fail ini akan menjadi templat pemaparan komponen Vue.js Kod adalah seperti berikut:
<!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>
Dalam kod di atas:
<meta name="csrf-token" content="{{ csrf_token() }}">
digunakan untuk merentas domain. pertahanan serangan; <link rel="stylesheet" href="{{ mix('css/app.css') }}" />
memperkenalkan gaya; <div id="app">
berfungsi sebagai bekas untuk komponen Vue.js; <example-component></example-component>
Seterusnya, cipta komponen folder baharu dalam direktori resources/js/ dan buat fail ExampleComponent.vue baharu di dalamnya. Fail ini ialah komponen fail tunggal Vue yang akan diberikan kepada fail vue.blade.php. Kodnya adalah seperti berikut: <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>
digunakan untuk memasukkan gaya komponen fail tunggal. <script>
6 Gunakan komponen Vue.js dalam templat Blade <style>
@extends('index.vue') @section('content') <example-component></example-component> @endsection
menentukan kedudukan pemaparan untuk komponen Vue.js dan
menentukan nama komponen yang akan dipanggil. 7. Susun kod bahagian hadapan@extends('index.vue')
Apabila anda melaksanakan perintah berikut untuk menyusun, public/js/app.js dan public/css/app.css akan dijana secara automatik. Kesannya boleh dilihat melalui fail HTML dalam direktori awam. @section('content')
npm run dev
example-component
8. Integrasikan Vue.jsSelepas menyepadukan Laravel Mix ke dalam projek ThinkPHP, langkah seterusnya ialah menyepadukan Vue.js. Kebergantungan Laravel Mix dan Lodash.debounce digunakan di sini Kodnya adalah seperti berikut:
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 } } }); }
Dalam kod di atas:
.vue({ version: 2 }) digunakan untuk. beritahu projek Laravel Mix untuk menggunakan Versi Vue.js; .babel() digunakan untuk menjalankan Vue.js dalam IE8; dan item konfigurasi kepada pembina.php think run
Atas ialah kandungan terperinci Bagaimana untuk menggunakan vue dalam thinkphp. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!