Laravel+Vue.js-如何拥有全局变量



我有一个使用Laravel和Vue.js的项目。我想不把它们分开不是最好的主意,但我们从错误中吸取了教训;(以下是它的工作原理:

我一直在努力放置全局变量,比如"当前用户"。现在,每当我需要它,或者我把它放在道具中时,我都会通过axios调用/currentuser,但它让我疯狂。。。如何使其全球化?我想知道Vuex是否可以在我的项目中工作,因为所有东西都是从Laravel调用的,路线也是。。。

我在app.js中尝试了几种方法(这里有两种,混合使用(:

var curruser=null;
axios.get('/currmember').then(
response => {
curruser=response.data;
}
);
Vue.mixin({
methods: {
},
data: function() {
return {
myvaiable: '', //this doesn't work eather
get currentUser() {
if(curruser==null){
axios.get('/currmember').then(
response => {
curruser=response.data;
return curruser;
}
);
}
return curruser;
}
}
}
});}

在TestComponent.vue 中

<template>
<div>
{{currentUser}}
{{myvariable}} <!-- none of them display anything -->
</div>
</template>

以下是事情的运作方式(非常简化(:

app.js

import Vue from 'vue';
window.Vue = require('vue');
var App = Vue.component('app', require('./App.vue').default, {
name: 'app'
}); 
var shol = Vue.component('test', require('./components/TestComponent.vue').default); 
let lang=localStorage.Lang!=null?localStorage.Lang:'fr';// = document.documentElement.lang.substr(0, 2); 
init();

function init(){
const app = new Vue({
el: '#app',
i18n,
components:{test
}
});
var curruser=null;
axios.get('/currmember').then(
response => {
curruser=response.data;
}
);

Vue.mixin({
methods: {
},
data: function() {
return {
currentUser: 'blabla',
get currentUser2() {
if(curruser==null){
axios.get('/currmember').then(
response => {
curruser=response.data;
console.log(curruser);
return curruser;
}
);
}
return curruser;
}
}
}
});}

test.blade.php

@extends('template')
@section('pageTitle', 'test' )
@section('contenu')
<div >
<test></test>
</div>
@endsection

web.php
Route::get('/test', function () {
return view('test');
});

您可以使用vuex访问当前已验证的用户:

关于app.js:

import Vue from 'vue';
import store from './store';
const app = new Vue({
el: '#app',
store,
i18n,
components:{ test },
created() {
store.dispatch('getUser');
}
});

store.js:

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex);
export default new Vuex.Store({
state: {
user: {},
},
getters: {
user: state => state.user,
},
mutations: {
setUser(state, user) {
state.user = user;
},
},
actions: {
getUser({ commit }) {
return new Promise((resolve, reject) => {
axios.get('/currmember')
.then(result => {
commit('setUser', result.data);
resolve();
})
.catch(error => {
reject(error.response && error.response.data.message || 'Error.');
});
});
},
}
})

test组件:

<template>
<div>
{{ currentUser }}
</div>
</template>
<script>
export default {
computed: {
currentUser() {
return this.$store.state.user;
}
}
};
</script>

最新更新