웹 기술의 지속적인 발전으로 프론트엔드와 백엔드의 분리가 트렌드가 되었습니다. 프런트엔드 프레임워크인 Vue.js가 점점 더 대중화되고 있는데, ThinkPHP에서 Vue를 어떻게 사용하나요? 이 기사에서는 ThinkPHP5.1 프레임워크를 사용하여 Vue.js를 통합하는 방법을 소개합니다.
1. Node.js 설치
시작하기 전에 Node.js 환경이 설치되어 있는지 확인하세요. 그렇지 않은 경우 공식 웹사이트로 이동하여 다운로드하여 설치할 수 있습니다.
2. 새 프로젝트 만들기
Composer 명령을 사용하여 터미널에 다음 명령을 입력합니다.
composer create-project topthink/think=5.1.* myapp
위 명령을 실행하면 현재 경로에 myapp 폴더가 생성됩니다. 그런 다음 다음을 실행하여 디렉터리를 입력하고 ThinkPHP 종속성을 설치합니다.
cd myapp composer install
3. 프런트엔드 종속성을 설치합니다.
myapp 디렉터리를 입력했는지 확인한 후 명령줄 도구에 다음 지침을 입력하여 필수 항목을 설치합니다. front-end dependency:
npm install
설치가 완료되면 myapp 디렉터리 아래 node_modules 폴더에서 성공적으로 설치된 종속성 패키지를 확인할 수 있습니다.
4. 구성 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을 다른 빌드 도구와 결합하여 프런트 엔드 작업 흐름을 통합하는 데 사용됩니다.
5. Vue.js 구성 요소 만들기
Vue.js 구성 요소 작성을 시작하기 전에 먼저 resources/views 디렉터리를 만들고 그 아래에 새 폴더 색인을 만든 다음 색인 폴더에 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 () }}" >
도메인 간 공격 방어에 사용됩니다. <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
<link rel="stylesheet" href="{{ mix('css/app.css') }}" />
Vue.js 구성 요소의 컨테이너로 <div id="app">
소개; ;/example-comComponent>< /code>는 Vue.js 구성 요소입니다. 다음으로 resources/js/ 디렉터리에 새 폴더 구성 요소를 만들고 그 안에 새 exampleComponent.vue 파일을 만듭니다. 이 파일은 vue.blade.php 파일로 렌더링되는 Vue 단일 파일 구성 요소입니다. 코드는 다음과 같습니다.
npm run dev
위 코드에서:
<template>
태그는 HTML 템플릿을 삽입하는 데 사용됩니다. <script>
태그 JavaScript 코드를 삽입하는 데 사용되며 내보내기 기본값을 통해 Vue 단일 파일 구성 요소를 내보내는 데 사용됩니다. <style>
태그는 단일 파일 구성 요소의 스타일을 삽입하는 데 사용됩니다. 위 단계를 완료한 후 블레이드 템플릿에서 Vue.js 구성 요소를 사용하여 다음 코드를 추가할 수 있습니다.
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 } } }); }
@extends(' code index.vue')
는 방금 생성된 vue.blade.php 템플릿을 참조하고, @section('content')
는 example -comComponent
는 호출할 구성 요소 이름을 지정합니다.
7. 프론트엔드 코드 컴파일
🎜다음 명령어를 실행하여 컴파일하면 public/js/app.js와 public/css/app.css가 자동으로 생성됩니다. 효과는 공개 디렉토리의 HTML 파일을 통해 확인할 수 있습니다. 🎜php think run
위 내용은 thinkphp에서 vue를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!