php - Vue.js 2.0 无法编译模板

标签 php laravel vue.js

我使用 webpackvue.js 2.0Laravel 5.3。当我用 gulp 编译时没有任何问题。

但是当我转到链接到 home.blade.php/home 时,我在控制台中收到此错误。

错误:

vue.js?3de6:515 [Vue warn]: failed to compile template:

//my component

(found in root instance) 

app.js

require('./bootstrap');


Vue.component('CheckoutForm', require('./components/CheckoutForm.vue'));

const app = new Vue({
    el: '#app'
});

app.blade.php

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <!-- CSRF Token -->
    <meta name="csrf-token" content="{{ csrf_token() }}">

    <title>{{ config('app.name', 'Laravel') }}</title>

    <!-- Styles -->
    <link href="/css/app.css" rel="stylesheet">

    <!-- Scripts -->
    <script>
        window.lnj = <?php echo json_encode([
            'csrfToken' => csrf_token(),
            'stripeKey' => config('services.stripe.key')
        ]); ?>
    </script>
</head>
<body>
    <div id="app">
        <nav class="navbar navbar-default navbar-static-top">
            <div class="container">
                <div class="navbar-header">

                    <!-- Collapsed Hamburger -->
                    <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#app-navbar-collapse">
                        <span class="sr-only">Toggle Navigation</span>
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span>
                    </button>

                    <!-- Branding Image -->
                    <a class="navbar-brand" href="{{ url('/') }}">
                        {{ config('app.name', 'Laravel') }}
                    </a>
                </div>

                <div class="collapse navbar-collapse" id="app-navbar-collapse">
                    <!-- Left Side Of Navbar -->
                    <ul class="nav navbar-nav">

                    </ul>

                    <!-- Right Side Of Navbar -->
                    <ul class="nav navbar-nav navbar-right">
                        <!-- Authentication Links -->
                        @if (Auth::guest())
                            <li><a href="{{ url('/login') }}">Login</a></li>
                            <li><a href="{{ url('/register') }}">Register</a></li>
                        @else
                            <li class="dropdown">
                                <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">
                                    {{ Auth::user()->name }} <span class="caret"></span>
                                </a>

                                <ul class="dropdown-menu" role="menu">
                                    <li>
                                        <a href="{{ url('/logout') }}"
                                            onclick="event.preventDefault();
                                                     document.getElementById('logout-form').submit();">
                                            Logout
                                        </a>

                                        <form id="logout-form" action="{{ url('/logout') }}" method="POST" style="display: none;">
                                            {{ csrf_field() }}
                                        </form>
                                    </li>
                                </ul>
                            </li>
                        @endif
                    </ul>
                </div>
            </div>
        </nav>

        @yield('content')
    </div>

    <!-- Scripts -->
    <script src="https://checkout.stripe.com/checkout.js"></script>
    <script src="/js/app.js"></script>
</body>
</html>

home.blade.php

@extends('layouts.app')

@section('content')
<div class="container">
    <div class="row">
        <div class="col-md-8 col-md-offset-2">
            <div class="panel panel-default">
                <div class="panel-heading">Dashboard</div>

                <div class="panel-body">
                    <checkout-form :plans="{{ $plans }}"></checkout-form>
                </div>
            </div>
        </div>
    </div>
</div>
@endsection

package.json

{
  "private": true,
  "scripts": {
    "prod": "gulp --production",
    "dev": "gulp watch"
  },
  "devDependencies": {
    "bootstrap-sass": "^3.3.7",
    "gulp": "^3.9.1",
    "jquery": "^3.1.0",
    "laravel-elixir": "^6.0.0-14",
    "laravel-elixir-vue-2": "^0.2.0",
    "laravel-elixir-webpack-official": "^1.0.2",
    "lodash": "^4.16.2",
    "vue": "^2.0.1",
    "vue-resource": "^1.0.3"
  }
}

checkoutForm.js(组件)

<template>
    <form action="/subscriptions" method="POST">
        <select name="plans" v-model="plan">
            <option v-for="plan in plans" :value="plan.id">
                {{ plan.plan }} &mdash; {{ plan.price / 100 }}
            </option>
        </select>

        <button type="submit" @click.prevent="subscribe">Koop het hier!</button>

        <p v-show="status" v-text="status"></p>
    </form>
</template>

<script>
    export default {
        props: ['plans'],

        data() {
            return {
                stripeEmail: '',
                stripeToken: '',
                status: false,
                plan: 1
            };
        },

        created() {
            this.stripe = StripeCheckout.configure({
                key: lnj.stripeKey,
                locale: "auto",
                panelLabel: "Subscribe For",
                token: (token) => {
                    this.stripeToken = token.id;
                    this.stripeEmail = token.email;

                    this.$http.post('/subscriptions', this.$data)
                            .then(
                                response => alert("Success!"),
                                response => this.status = response.body.status
                            );
                }
            });
        },

        methods: {
            subscribe() {
                let plan = this.findPlanById(this.plan);
                this.stripe.open({
                        'Name': plan.name,
                        'description': plan.description,
                        'zipCode': true,
                        'currency': "eur",
                        'amount': plan.price
                });
            },

            findPlanById(id) {
                return this.plans.find(plan => plan.id == id);
            }
        }
    }
</script>

可能是什么问题?

最佳答案

首先确保您的组件没有命名为 checkoutForm.js,而它应该是 checkoutForm.vue,否则 webpack 将使用不正确的加载器。

在您的主 app.js 中,您需要将组件重命名为小写连字符:

Vue.component('checkout-form' ...

然后您将 this.stripe 设置为 StripeCheckout 的实例

相反,你应该:

checkoutForm.js

data() {
   return {
      stripeEmail: '',
      stripeToken: '',
      status: false,
      plan: 1
   };
},

stripe: null,

created() {
   this.$options.stripe = StripeCheckout.configure({
   ...

然后始终引用 this.$options.stripe 否则 Vue 将尝试使 stripe 响应式

关于php - Vue.js 2.0 无法编译模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40849885/

相关文章:

Laravel 帆 + 黄昏 + Selenium : Connection refused

php - laravel 中 URL::to 和 URL::route 的区别

ajax - 使用 Vue.js 在父级中运行 ajax 调用并在子级中调用成功

php - 更新包含包含文件的 div

php - 在 ICU 中,是否可以使用自定义复数规则而不是 CLDR 规则

php - 如何在 html 中呈现多层次的 mysql 查询(codeIgniter)

javascript - 表未显示 laravel vue 组件中数据库的数据

php - 从取消的 WooCommerce 订单中减少产品总销售额

mysql - Laravel - 如何插入带有保留字和破折号的行

vue.js - 尝试将表格插入鹅毛笔编辑器时出现错误 "[Parchment] Unable to create table blot"