我有一个使用 Laravel 和 Vue.js 的项目。我想不将它们分开并不是最好的主意,但我们从错误中吸取教训 ;) 以下是它的工作原理:
我一直在努力尝试放置全局变量,例如“当前用户”。现在,我每次需要时都会通过 axios 调用 /currentuser,或者我将它放在 props 中,但它让我发疯了......我怎样才能使它全局化?我想知道 Vuex 是否可以在我的项目中工作,因为一切都是从 Laravel 调用的,路由也是......
我在 app.js 中尝试了几件事(这里有 2 个,混合):
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;
}
}
}
});}
Run Code Online (Sandbox Code Playgroud)
在 TestComponent.vue 中
<template>
<div>
{{currentUser}}
{{myvariable}} <!-- none of them display anything -->
</div>
</template>
Run Code Online (Sandbox Code Playgroud)
这是事情的运作方式(非常简化它们):
应用程序.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;
}
}
}
});}
Run Code Online (Sandbox Code Playgroud)
测试刀片.php
@extends('template')
@section('pageTitle', 'test' )
@section('contenu')
<div >
<test></test>
</div>
@endsection
web.php
Route::get('/test', function () {
return view('test');
});
Run Code Online (Sandbox Code Playgroud)
您可以使用 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');
}
});
Run Code Online (Sandbox Code Playgroud)
的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.');
});
});
},
}
})
Run Code Online (Sandbox Code Playgroud)
该test组件:
<template>
<div>
{{ currentUser }}
</div>
</template>
<script>
export default {
computed: {
currentUser() {
return this.$store.state.user;
}
}
};
</script>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2250 次 |
| 最近记录: |