laravel - Laravel + Vue.js - 如何拥有一个全局变量?
问题描述
我有一个使用 Laravel 和 Vue.js 的项目。我想不将它们分开不是最好的主意,但我们从错误中吸取教训;)这是它的工作原理:
我一直在努力尝试放置全局变量,例如“当前用户”。现在,我每次需要它时都会通过 axios 调用 /currentuser,或者我把它放在道具中,但这让我发疯了......我怎样才能让它全球化?我想知道 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;
}
}
}
});}
在 TestComponent.vue
<template>
<div>
{{currentUser}}
{{myvariable}} <!-- none of them display anything -->
</div>
</template>
以下是事情的运作方式(非常简化它们):
应用程序.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>
推荐阅读
- python - 为什么转换进入数据集而不是 Pytorch 中的 NN 本身?
- python - 在 ForeignKey 中创建或获取默认对象
- javascript - 想要在第一个语句完成执行后重定向反应
- vagrant - 初始化 Fabric CA 服务器时出错,go-sqlite3 需要 cgo 才能工作
- c# - 传递给 ViewDataDictionary 的模型项的类型是......但是这个 ViewDataDictionary 实例需要一个类型的模型项...... NET Core MVC
- python - python将多列一一添加到excel文件中
- r - 在R中的绘图中添加垂直线连接点到水平线
- python - 如何使用python创建一个一张一张地绘制散点图的视频?
- wordpress - 从头开始构建 woocommerce php 模板,为订单等工作
- javascript - React & TS - 删除嵌套数组而不删除其对象?