Rumah > rangka kerja php > ThinkPHP > Bagaimana untuk menggunakan vue dalam thinkphp

Bagaimana untuk menggunakan vue dalam thinkphp

王林
Lepaskan: 2023-05-28 22:30:07
asal
1500 orang telah melayarinya

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
Salin selepas log masuk

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
Salin selepas log masuk

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
Salin selepas log masuk

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');
Salin selepas log masuk

Fungsi kod di atas ialah:

  • Pengenalan Alat Laravel Mix
  • Nyatakan sumber fail masukan/js/app.js dan laluan keluaran kompilasi sumber public/js
  • Tentukan sumber laluan fail masukan Sass/sass/app.scss dan laluan keluaran kompilasi public /css

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>
Salin selepas log masuk

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>
    Salin selepas log masuk
Dalam kod di atas:

teg digunakan untuk memasukkan templat HTML; untuk memasukkan kod JavaScript, melalui eksport lalai eksport komponen fail tunggal Vue teg
  • <template> digunakan untuk memasukkan gaya komponen fail tunggal.
  • <script>6 Gunakan komponen Vue.js dalam templat Blade
  • Selepas melengkapkan langkah di atas, anda boleh menggunakan komponen Vue.js dalam templat Blade untuk menambah kod berikut : <style>
    @extends('index.vue')
    
    @section('content')
      <example-component></example-component>
    @endsection
    Salin selepas log masuk
dalam kod di atas merujuk kepada templat vue.blade.php yang baru dibuat,

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
Salin selepas log masuk
example-component8. Integrasikan Vue.js

Selepas 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
      }
    }
  });
}
Salin selepas log masuk

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.

    9 Bersedia
  • Selepas melengkapkan semua langkah di atas, anda boleh berjaya menggunakan Vue.js dalam projek ThinkPHP. Jalankan arahan berikut untuk memulakan pelayan setempat untuk melihat kesannya:
  • php think run
    Salin selepas log masuk
    Di atas adalah beberapa kaedah dan langkah untuk menggunakan Vue.js dalam ThinkPHP. Atas dasar ini, anda juga boleh menyelesaikan masalah yang lebih kompleks melalui konfigurasi yang lebih terperinci, seperti menghantar data melalui API, mengkonfigurasi penghalaan, dsb. Saya harap kaedah di atas dapat membantu anda dalam amalan anda.
  • Atas ialah kandungan terperinci Bagaimana untuk menggunakan vue dalam thinkphp. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan