php laravel / vuejs部署我的vuejs视图不呈现

时间:2018-05-23 11:31:43

标签: php laravel vue.js ftp node-modules

我有一个使用laravel 5.5和vuejs 2.5.7的项目。 在localhost上一切正常,但在生产时,我的vuejs组件无法渲染。 我的所有要求都很好,我只有200。 我已经完成了npm run production并将app.js文件设置到我的文件夹public_html / js

我有两个文件夹:

  • public -js / app.js //在npm运行生产之后 -index.php -CSS -图片 -etc ...
  • alpha所有其他文件 -vendor -node模块 -ressources -etc ...

我的主页:

<!DOCTYPE html>

<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', 'AlphaTeen') }}</title>

<!-- Styles -->
<link href="{{ asset('css/app.css') }}" rel="stylesheet">
<link href="{{ asset('css/main.css') }}" rel="stylesheet">
<link href="{{asset('css/bootstrap-social.css')}}" rel="stylesheet">
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font- 
awesome.min.css" rel="font-awesome">

</head>
<body>

    @yield('content')
<!-- Scripts -->
<script src="{{ asset('js/app.js') }}"></script>//after having done npm run 
production
</body>
</html>

我的php文件:

@extends('layouts.vue_app')

@section('content')

<div id="products"></div>
<script>
        window.Laravel=<?php echo json_encode([
            'csrfToken'=> csrf_token(),
        ]); ?>
        </script>
@endsection

我的App.vue:

<template>

  <div>
      <transition name="fade">
          <router-view></router-view>
      </transition>
  </div>

</template>

我的app.js文件正在呈现路线:

import Vue from 'vue';
import Vuelidate from 'vuelidate';
import VueRouter from 'vue-router';
import VueAxios from 'vue-axios';
import axios from 'axios';
import Paginate from 'vuejs-paginate';

Vue.use(VueRouter);
Vue.use(Vuelidate);
Vue.use(VueAxios,axios);
Vue.component('paginate',Paginate)

import App from './App.vue';
import Products from './components/Products.vue';
import Categories from './components/Categories.vue'; 
import Social from './components/Social.vue';
import Explain from './components/Explain.vue';
import Login from './components/Login.vue';
import Mail from './components/Mail.vue';
import Home from './components/Home.vue';
import testCloud from './components/admin/cloudVue.vue';
import Cloud from './components/admin/cloud.vue';
import Comments from './components/admin/comments.vue';

window.onload=function(){
const router=new VueRouter({mode:'history',routes:routes});
new Vue(Vue.util.extend({router},App)).$mount('#products');};

我正在使用webpack.mix.js:

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

我用ftp完成了所有转移,我知道这不是最好的解决方案,但我必须这样做。 这是我关于stackOverFlow的第一个问题,所以我希望能够清楚。 感谢

1 个答案:

答案 0 :(得分:0)

您的资产(js,css)可能会被缓存,尝试在不同的浏览器中打开您的页面或打开Chrome devtools并检查&#34;禁用缓存&#34; (虽然chrome devtools是打开选项),然后重新加载页面。

右键单击 - &gt;检查 - &gt;网络标签 - &gt;禁用缓存

然后使用cmd + r或刷新按钮

重新加载页面

enter image description here