狀態管理工具vuex的基本使用(vuebus的理解)

vuex的展示圖

在這里插入圖片描述

1. vuex 的基本結構

const store = new Vuex.Store({state: {} //相當于 vue結構中的 data getters: {}, // 相當于vue結構中的計算屬性使用actions: {}, // 相當于vue結構中的監聽屬性使用mutations: {},//相當于vue結構中的 methods 方法集合 (其中方法第一個參數為vuex的參數,第二個為調用時傳遞的參數 )modules:{} //  其中客包含另一個vuex 存在,相當大的模塊包
})

1.1 vuex 數據持久化設置

數據持久化設置:

2. vuex 的基本使用

import Vue from 'vue'
import Vuex from 'vuex'
import router from '@/router/router.js'Vue.use(Vuex)export default new Vuex.Store({state: {// isOpen: localStorage.getItem("EP_ADMIN_isOpen") == 'true' ? true : false,// isFixed: localStorage.getItem("EP_ADMIN_isFixed") == 'true' ? true : false,isOpen: true,isFixed: true,querylogoimg:"",},mutations: {setIsOpen(state, val) {state.isOpen = vallocalStorage.setItem("EP_ADMIN_isOpen", val)},setIsFixed(state, val) {state.isFixed = vallocalStorage.setItem("EP_ADMIN_isFixed", val)},logocahnge(state , value){// console.log(value);state.querylogoimg = value},},actions: {},modules: {}
})

3. vuex 的頁面使用

<script>
import { mapMutations, mapState } from "vuex"
import Api_login from "@/assets/api/login"
export default {data() {return {username: '',// querylogoimg:"",Defaultlogo:require("../../assets/img/login/logo-headportrait.png"),}},computed: {...mapState([ 'isOpen',  'isFixed'])},created() {},mounted() {this.getUserInfoFun(); // 獲取登錄者用戶信息},methods: {...mapMutations(['setIsOpen', 'setIsFixed' , 'logocahnge' ]),getUserInfoFun(){// this.querylogoimg = let _this = this;// 獲取用戶信息Api_login.getUserInfo().then(res => {if (res.success) {this.username = res.result.name;// 存儲頭像圖片信息this.$store.commit('logocahnge' ,  res.result.avator)let jsonData = JSON.stringify(res.result);_this.$store.commit("setUserInfo", jsonData);utils.init(this);}});},}
}
</script>也可在 DOM 結構上使用:
<img :src="$store.state.querylogoimg == null ? Defaultlogo : $store.state.querylogoimg" alt="">

最后說下 vuex 中 的 modules

1. 取文件夾中其中一個做代表

在這里插入圖片描述

2.文件夾結構使用方式

在這里插入圖片描述
vuebus使用描述推薦:https://blog.csdn.net/qq_41630382/article/details/84100016?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522162813297116780264087097%2522%252C%2522scm%2522%253A%252220140713.130102334…%2522%257D&request_id=162813297116780264087097&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduend~default-1-84100016.pc_search_result_control_group&utm_term=vue+bus%E4%BD%BF%E7%94%A8&spm=1018.2226.3001.4187

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/247811.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/247811.shtml
英文地址,請注明出處:http://en.pswp.cn/news/247811.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Memcache

前戲 Memcached是一個高性能的分布式內存對象緩存系統&#xff0c;用于動態Web應用以減輕數據庫負載。它通過在內存中緩存數據和對象減少讀取數據庫的次數&#xff0c;從而減小數據庫的壓力&#xff0c;提高動態&#xff0c;數據庫網站的速度。Memcached基于一個存儲 鍵/值對的…

解決Button自動刷新頁面的問題

一、問題 <button class"am-btn am-btn-default am-btn-xs am-text-secondary" data-id"99" data-type1><span class"am-icon-pencil-square-o"></span>修改</button>11 頁面上有這樣一個按鈕&#xff0c;每次點擊這個…

Django.1

Django官方網站&#xff1a;https://www.djangoproject.com/ 使用終端創建Django文件 創建工程 django-admin startproject XXX 創建應用 python manage.py startapp YYY 遷移系統指令&#xff1a; 首先生成遷移文件 python manage.py makemigrations 執行遷移文件 python ma…

vue項目水印添加

import DomSize from wd-domsize-monitor; // 此處為 npm 下載的第三方模塊包 import Api_login from "/assets/api/login" // 此處是用戶信息接口調用var id shuiyinDiv var isInit false let callback function (ele) {DomSize.bind(ele, function () {//水印被…

mybatis傳參

在mybatis的學習中&#xff0c;會發現經常需要傳參&#xff0c;這里以上一節寫的實體類為基礎&#xff0c;當我們要添加一個員工時&#xff0c;需要添加員工的基本信息&#xff0c;以及所屬部門&#xff0c;按照以前的方法&#xff0c;在實體類中&#xff0c;添加部門id屬性&am…

自定義步驟條

展示圖&#xff1a; <template><div classcreateorder><!-- 頂部步驟條 --><div class"createorder_top"><div class"createorder_top_left"><!-- 0 --><span class"createorder_left_set" :class"…

jquery讓頁面滾動到底部

function scrollToEnd(){//滾動到底部var h $(document).height()-$(window).height();$(document).scrollTop(h); }

迭代器

一、定義 1.iterator.(迭代器&#xff09; 2.iterable.&#xff08;可迭代的&#xff09; 一般來說&#xff0c;可以被for循環的就是可以迭代的&#xff0c;迭代器一定可以迭代&#xff0c;但是可迭代的類型不一定是迭代器。 二、說明 1.有__iter__方法&#xff0c;說明可迭代 …

css獲取到指定元素的寬度,在回調返回寬度值

<script type"text/javascript">//獲取到指定元素的寬度&#xff0c;在回調返回寬度值//通過處理這個value&#xff0c;重新設置新的寬度$(.sixth).css("width",function(index,value){//value帶單位&#xff0c;先分解value value.split(px);//返回…

android 文件讀寫

讀取&#xff1a; public static String _getJsonString(String fileName) throws IOException { if ((fileName null) || fileName.isEmpty()) { return ""; } String retString ""; FileInputStream fis null; String state Environment.getExternal…

element組件庫中table自定義分頁效果

1.在data中設置初始值 // 頁數 頁碼search: { offset: 1, // 當前頁limit: 10, // 條數total:0, //總數},2.設置獲取后的數據分配 :data"tableData.slice((search.offset - 1) * search.limit, search.offset * search.limit)" 3.展示效果&#xff1a;

Django信號量

信號 Django中提供了“信號調度”&#xff0c;用于在框架執行操作時解耦。通俗來講&#xff0c;就是一些動作發生的時候&#xff0c;信號允許特定的發送者去提醒一些接受者。 1、Django內置信號 1 Model signals2 pre_init # django的modal執行其構造方…

uni-app 調用接口封裝文檔

1.創建 util 文件夾 &#xff0c;并在文件夾中創建 api.js const BASE_URL http://localhost:8082 // 域名頭 export const myRequest (options)>{return new Promise((resolve,reject)>{uni.request({url:BASE_URLoptions.url,method: options.method || GET,data: …

HTML中INPUT type=date標簽如何賦值注意問題

現在的html5 input標簽支持type"date" 顯示有日期的日歷控件&#xff0c;一行簡單的代碼就能顯示出一個日歷控件&#xff0c;但是有的時候需要給它一個默認的日期值&#xff0c;這個時候可能就要用到val()&#xff0c; attr("value","")等方法&a…

數據輪播圖翻頁封裝(左右點擊)

效果圖&#xff1a; <template><div class"box" style"height:200px;"><!-- 左 --><div class"box-left" click"submitrote(left)" mouseenter"chenge_menu(1)" mouseleave"chenge_menu(2)"…

jquery自動點擊按鈕

jquery自動點擊按鈕$(document).ready(function(){$("#imgcode_img").trigger("click");});

087-把PHP數組中的元素按隨機順序重新排列shuffle

<?php$arrarray(3,23,A,f,123,hello); //定義一個數組echo 排序之前的數組信息&#xff1a;<br>;print_r($arr);shuffle($arr); //對數組進行隨機排序echo <br>排序之后的數組信息&#xff1a;<br>;print_r($arr); //輸出數組信息#…

highcharts圖表高級入門之polar:極地圖的基本配置以及一些關鍵配置說明

highcharts圖表組件內的極地圖polar的實現和效果都還是很簡單和美觀的。 1、需要設置chart的polar屬性為true&#xff1b;以表示是極地圖&#xff1b; 2、其他的設置和普通圖表就沒什么區別了的&#xff0c;這里附上一個完整的示例代碼&#xff1a; highcharts圖表組件內的極地…

基于Element ui 實現輸入框只能輸入數字并支持千分位

實現效果 設置子組件 <template><el-inputref"money"v-model.trim"money":placeholder"placeholder"v-bind"$attrs"v-on"$listeners"input"formatNumber(money,money)"keyup.enter.native"moneyCh…

Vue-使用webpack+vue-cli搭建項目

一、準備 安裝NodeJs 安裝Webpack 配置環境變量 技巧使用&#xff1a; 1. npm 淘寶路徑配置&#xff1a;npm config set registryhttps://registry.npm.taobao.org  2.查看npm命令列表 > $ npm help 二、搭建項目 1、全局安裝vue腳手架工具 vue-cli npm install vue…