在Laravel5.4中使用Vue2.1

在laravel5.4中已经内置了vuejs前端框架,这里介绍如何使用它们一起工作。
假设你已经安装好相关的依赖:

  1. 编辑routes/web.php
Route::get('/', function () {
    return view('welcome');
});

我们的首页将会显示welcome.blade.php这个页面。

  1. 修改resources/views/welcome.blade.php,修改页面的body部分
<body>
  <!-- vue的挂载点-->
   <div id='app'>
        <!--使用我们建立的组件-->
        <example></example>
   </div>
  <!--载入打包后的js-->
  <script src="js/app.js"></script>
</body>
  1. 建立resources/assets/js/components/Example.vue
<template>
    <div class="container">
        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <div class="panel panel-default">
                    <div class="panel-heading">{{ name || '匿名'}}</div>
                    <div class="panel-body">
                        {{msg}}
                    </div>
                </div>
            </div>
        </div>
    </div>
</template>

<script>
export default {
  props: ['name'],
  data () {
    return {
        msg: '这是laravel下的一个vue组件example.'
    }
  }
}
</script>
  1. 修改resources/assets/js/bootstrap.js
    加入window.Vuw = require('vue');
  2. 修改resources/assets/js/app.js
require('./bootstrap');

import Example from './components/Example'
new Vue({
  el: '#app',
  components: { Example }
})

这个文件被打包后会在welcome.blade.php中被使用。
以上部分总共建立了三个文件

  • welcome.blade.php: laravel的样板页
  • Example.vue: vue单文件组件
  • app.js: 建立vue实体和注册vue组件
  1. 修改webpack.mix.js
    接下来就是打包了,打包会把.vue组件和.js编译成一个独立的.js文件,由于我们require('./bootstrap'),所以其中的js也会被一起打包。laravel5.4引入了mix,比之前的laravel elixir更简单好用,它使用webpack来执行打包,相应的设置在webpack.mix.js中,现在我们修改其中的内容:
let mix = require('laravel-mix');

mix.js('resources/assets/js/app.js', 'public/js')
   .sass('resources/assets/sass/app.scss', 'public/css');

目的是把resources/assets/js/app.js打包后放到public/js/app.js

  1. 打包并执行
    在cmd中切换到项目根目录,执行npm run devyarn run dev
    这样就打包完成了。
    接下来启动内置服务器php artisan serve
    顺利的话就可以在localhost上看到相应页面了。
  2. 自动打包更新
    由于我们必须打包后才能在网站上看到结果,这样每次对vue文件的修改后都要执行npm run dev,这样实在太没效率了,我们可以改用npm run watchyarn run watch指令来自动打包更新。
  3. 发布
    如果你想要开放public/js/app.js,由于它们是尚未被压缩的内容,而且引入了其它元件,文件大小有1MB多,这可不能拿来给实际的产品用。当你的网站要发布到产品服务器上时,必须使用npm run prodyarn run prod 来进行打包压缩。

抽取组件
通常你的网站不会只有一页,因此你会在不同的页面建立不同的.vue和.js文件,但是它们都是使用同样的一些组件,当你打包时,这些相同的组件就会被重复打包在不同的.js文件中,浪费资源。
我们可以将这些会重复使用的组件抽取出来,封装成一个独立的文件,这样只会在第一次载入时多花一点时间,之后浏览器就可以很快地从中读取,不会重复下载相同的内容。
先来看看我们使用了哪些组件,打开resources/assets/js/bootstrap.js,看看全局变量请求了哪些组件,有lodash,jquery,axios以及我们加入的vue,我们要将这些组件抽取成为一个独立的文件。
首先,编辑webpack.mix.js,使用extract指令来抽取组件:

mix.js('resources/assets/js/hello.js', 'public/js')
   .extract(['lodash','jquery','axios','vue']);

这样当你打包时就会产生2个额外文件和一个自己写的文件:

  • public/js/manifest.js: webpack manifest runtime
  • public/js/vendor.js: 使用的组件全部打成一包
  • public/js/hello.js: 自己的js文件,这里是hello.js

之后我们要稍微调整一下welcome.blade.php的<script>部分:

<script src="js/manifest.js"></script>
<script src="js/vendor.js"></script>
<script src="js/app.js"></script>

为了避免JavaScript执行时发生错误,必须按照上面的顺序,自己的js放在最后载入。

这样就完成了组件的抽取。

不过,在laravel中,我们通常会使用layout将页面中的公共部分抽取出来。下面介绍laravel中layout的写法:
假设你有一个layout文件resources/views/layouts/app.blade.php:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>@yield('title')</title>
</head>
<body>
    <div id="app">
        @yield('content')
    </div>
    <script src="/js/manifest.js"></script>
    <script src="/js/vendor.js"></script>
    @yield('script')
</body>
</html>

我们指定了三个准备填入的内容title,content,script .
接着修改resources/views/welcome.blade.php

@extends('layouts.app')

@section('title', 'Laravel With Vue Demo')

@section('content')
    <Hello name="Tony"></Hello>
    <Hello></Hello>
@endsection

@section('script')
    <script src="js/hello.js"></script>
@endsection

只要使用同一个layout的页面,内容差不多就是这样,并且原本写在这里的代码可以直接写到vue中了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容