首页 > 其他分享 >假期vue学习笔记16 vuex多组数据共享

假期vue学习笔记16 vuex多组数据共享

时间:2024-02-28 17:55:50浏览次数:32  
标签:vue name 16 sum value state 数据共享 import store

 

<template>     <div>         <h1>当前求和为:{{sum}}</h1>         <h1>十倍的和为:{{bigSum}}</h1>         <h1>{{xuexiao}}</h1>         <h1>{{xueke}}</h1>         <h3>下方总人数为:{{$store.state.personList.length}}</h3>         <select v-model.number="n">             <option value="1">1</option>             <option value="2">2</option>             <option value="3">3</option>         </select>         <button  @click="increment(n)">+</button>         <button  @click="decrement(n)">-</button>         <button  @click="incrementOdd">当前求和为基数再加</button>         <button  @click="incrementWait">等一等再加</button>     </div> </template>
<script> import {mapState,mapGetters,mapMutations} from "vuex";     export default{         name:'Count',         data() {             return {                 n:1, //用户选择的数字             }         },         methods:{
            ...mapMutations({increment:'JIA',decrement:'JIAN',personList:'personList'}),
            incrementOdd(){                 if(this.$store.state.sum % 2){                     this.$store.dispatch('jia',this.n)                 }                             },
            incrementWait(){                 setTimeout(()=>{                     this.$store.dispatch('jia',this.n)                 },500)             }         },         computed:{             //借助mapstate生成计算属性。从state中读取数据。(对象写法)             // ...mapState({he:'sum',xuexiao:'school',xueke:'subject'})             //数组写法             ...mapState(['sum','school','subject']),
            ...mapGetters({bigSum:'bigSum'})         }
    } </script>
<style>     button{         margin-left: 5px;     } </style>     <template>     <div>         <h1>人员列表</h1>         <input type="text" placeholder="请输入名字" v-model="name">         <button @click="add">添加</button>         <ul>             <li v-for="p in personList" :key="p.id">{{p.name}}</li>         </ul>     </div> </template>
<script> import {nanoid} from "nanoid";     export default{         name:'Person',         data() {             return {                 name:''             }         },         computed:{             personList(){                 return this.$store.state.personList             }         },         methods:{             add(){                 const personObj = {id:nanoid(),name:this.name}                 this.$store.commit('ADD_PERSONS',personObj)                 this.name=''             }         }     } </script>

<style>

</style>     //该文件用于创建Vuex中最为核心的store import Vue from 'vue' import Vuex from 'vuex'
Vue.use(Vuex) //准备actions——用于响应组件中的动作 const actions = {     jia(context,value){         context.commit('JIA',value)     },     jian(context,value){         console.log('方法被调用了')         context.commit('JIAN',value)     } } //准备mutations——用于操作数据(store) const mutations = {     JIA(state,value){         state.sum += value     },     JIAN(state,value){         state.sum -= value     },     ADD_PERSONS(state,value){         state.personList.unshift(value)     } } //准备state——用于存储数据 const state = {     sum:0, //当前的和     school:'尚硅谷',     subject:'数学',     personList:[         {id:'001',name:'张三'}     ] } //用于将state中的数据进行加工 const getters = {     bigSum(state){       return  state.sum*10     } }

export default new Vuex.Store({     actions,     mutations,     state,     getters })   <template>         <div >             <Count/>             <Person/>         </div> </template>
<script>
import Count from './components/Count.vue' import Person from './components/Person.vue' export default{     name:'App',     components:{         Count,         Person     },     data() {         return {                 }     }, } </script>

<style lang="css">       </style>     import Vue from 'vue'
import App from './App.vue'
import store from './store'
Vue.config.productionTip = false

new Vue({     el:'#root',     render: h => h(App),     store,     beforeCreate(){         Vue.prototype.$bus = new Vue();     } })

标签:vue,name,16,sum,value,state,数据共享,import,store
From: https://www.cnblogs.com/hbro/p/18041275

相关文章

  • 假期vue学习笔记07 todo事件的本地存储
     用本地存储改写前面的todo案例 <template>    <li>      <label>        <inputtype="checkbox":checked="todo.done"@change="handleCheck(todo.id)"/>        <spanv-show="!tod......
  • 假期vue学习笔记08 绑定和解绑
     <template>  <divclass="app">    <h1>{{msg}}</h1>    <!--props子给父传递事件-->    <School:getSchoolName="getSchoolName"/>    <!--通过父组件给子组件绑定一个自定义事件实现:子给父传递数据(第一种写法,使用@过v-......
  • 假期vue学习笔记09 全局事件总栈
     <template>  <div class="school">    <h2>学校名称:{{name}}</h2>     <h2>学校地址:{{address}}</h2>  </div></template><script>  exportdefault{    name:'School'......
  • 假期vue学习笔记10 pubsub
     <template>  <divclass="app">    <h1>{{msg}}</h1>    <School/>    <Student/>  </div></template><script>importStudentfrom'./components/Student.vue'imp......
  • 假期vue学习笔记11 动画
    <template>  <divid="root">    <Test/>    <Test2/>    <Test3/>  </div></template><script>importTestfrom'./components/Test.vue'importTest2from'./comp......
  • 假期vue学习笔记01 ref
    <template>  <div>    <h1v-text="msg"ref="title"></h1>    <button@click="showDOM">点我输出上方的DOM元素</button>    <School/>  </div></template><script......
  • 假期vue学习笔记02 mixin
    <template>  <div >    <h2@click="showName">学校名称:{{name}}</h2>     <h2>学校地址:{{address}}</h2>  </div></template><script>  exportdefault{    name:'School'......
  • javaweb02-JavaScript&vue
    JavaScript控制网页行为js引入方式内部脚本:script标签外部脚本:js文件js基础语法书写语法区分大小写每行结尾分号可有可无,建议写上输出语句警告框window.alerthtml输出document.write浏览器控制台console.log变量用var关键字声明变量JavaScript是一......
  • 假期vue学习笔记04 插件
    exportdefault{  install(Vue){    //全局过滤器    Vue.filter('mySclice',function(value){      returnvalue.slice(0,4)    }),    //定义全局指令    Vue.directive('fbind',{      bind(......
  • 【vue】做一个从右边出来又回去的一个抽屉div
    前言:工作需要做一个从右往左出现的一个弹窗,要有抽屉效果,看了网上各种方法好多都不能用,最后试了一种可以用,但是忘记是哪个网址了,现在就是自己写一下这个随便以后用到方便找。做一个从右边出来又回去的一个抽屉divhtml代码<divclass="addBtn"@click="show">点击按钮出......