438 vuex:基本使用,传参,vue和vuex的配合使用,Vue脚手架3,使用Vuex改版 TodoMVC,actions,mapGetters,mapMutations,mapActions

2021-03-23 08:26

阅读:803

YPE html>

标签:集中式   包含   获取数据   tle   dos   todo   更新   scl   document   

一 、Vuex的介绍

vuex 是什么?

  • 状态管理工具
  • 状态:即数据, 状态管理就是管理组件中的data数据
  • Vuex 中的状态管理工具, 采用了 集中式 方式统一管理项目中组件之间需要通讯的数据 【共享的数据。】
  • [看图]

如何使用

  • 最佳实践 : 只将组件之间共享的数据放在 vuex 中, 而不是将所有的数据都放在 vuex 中
  • 也就是说: 如果数据只是在组件内部使用的, 这个数据应该放在组件中, 而不要放在 vuex
  • vuex 中的数据也是 响应式 的, 也就是说: 如果一个组件中修改了 vuex 中的数据, 另外一个使用的 vuex 数据的组件, 就会自动更新 ( vuex 和 localstorage的区别)

什么时候用 ?

  • 官网
  • 说明: 项目体量很小, 不需要使用 vuex, 如果项目中组件通讯不复杂, 也不需要使用 vuex
  • 只有写项目的时候, 发现组件通讯多, 组件之间的关系复杂, 项目已经无法继续开发了, 此时, 就应该使用 vuex

二、 Vuex的基本使用

vuex的基本使用

  • 安装 : npm i vuex
  • 引入 : 引入 vuex 之前一定要先引入 vue
  • 实例化 store
    • store 仓库 , 获取数据和操作数据都要经过 store
    • const store = new Vuex.Store()
  • 操作数据
    • 获取数据 : store.state.num
    • 操作数据 : store.state.num = 300
    • 虽然 store.state.count = 300 可以修改值 , 但是vuex 也有严格模式,
    • 添加严格模式 : strict : true,
  • 使用 mutations 【相当于methods】
    • 注册 : mutations : {}
    • increament(state) { state.count = 20; }
    • 默认第一个参数永远是 state
    • 触发事件 : store.commit(‘increament‘)

01-vuex的基本使用.html



Document

vuex的传参

  • **触发事件 : **

  • # 传参最好传一个对象,  多个值查看方便 
    store.commit(‘increament‘,   {
        num:  400
    })
    
  • 事件

  • # payload 载荷
    increament(state,   payload) {
    	state.count = payload.num
    }
    

02-传参.html






Document

vue和vuex的配合使用

需求 : 有个h1显示数字的标题, 点击按钮累加数字

  • 先用vue做出来效果
  • 再用vuex和vue配合使用
    • 实例化vuex的store
    • 实例化vue
    • 把store挂载到vue上
  • 操作数据
    • h1展示数据 :

      {{ $store.state.num }}

    • 点击触发事件修改数据 : this.$store.commit(‘addNum‘)
    • addNum(state) { state.num++ }

03-vue和vuex的配合使用.html






Document

{{ $store.state.num }}


三、Vue脚手架3.0

官网 : https: //cli.vuejs.org/zh/guide/installation.html

安装

  • 安装脚手架 2.x : npm i vue-cli -g
  • 安装脚手架 3.x : npm i -g @vue/cli
  • 检测脚手架版本号 : vue -V / --version

创建一个项目

  • 命令 : vue create vuex-todos (可视化 vue ui)
  • 可以选择默认配置或者手动配置
  • 开发运行 : npm run serve
  • 发布构建 : npm run build

四、使用Vuex改版 TodoMVC

  • 初始化项目
  • 拷贝模板(todomvc-app-template)里的结构(section部分)和样式 (node_modules里的)
  • 组件化
    • 创建 todo-header.vue、todo-list.vue、todo-footer.vue + scaf结构
    • app.vue 中 导入 : import todoheader from "./components/todo-header.vue";
    • 注册 : components: { todoheader , todolist , todofooter }
    • 使用 :
  • 配置 vuex 管理 list
    • 创建文件夹 store/store.js
    • 安装 vuex
    • 引入
    • vue安装vuex : Vue.use(Vuex)
    • 实例store, 并且导出 store
    • main.js 中引入并挂载到 vue 上
  • 列表展示
  • 删除任务
  • 添加任务
  • 修改任务
  • 修改状态
  • 计算属性(三个)
  • 清除已经完成的任务

五、如何使用 actions

技术图片


  • 官网介绍
  • Action 类似于 mutation,不同在于:
    • Action 可以包含任意异步操作。
    • Action 提交的是 mutation,而不是直接变更状态。
  • mutaions 里只能使用同步, 不能出现异步 (演示删除任务 里使用setTimeout 会报错)
  • 演示1: actions 可以包含任意异步操作。 代码1
  • 演示2: actions 不能直接变更状态 , 代码2 会报错
  • 演示3 : actions 提交的是 mutation
# 都是 actions 里
//演示1 : 
setTimeout(() => {
    console.log(‘actions‘)
},   0)

// 演示2 : 报错
setTimeout(() => {
    context.state.list = context.state.list.filter(
        item => item.id != payload.id
    )
},   0)

// 演示3 :  提交 mutations
setTimeout(() => {
    context.commit(‘delTodo‘,   payload)
},   0)

六、常用的几个辅助函数

mapGetters 辅助函数

  • store.js 中的几个计算属性 :

  • let getters = {
      isFooterShow(state) {
        return state.list.length > 0
      },  
      itemLeftCount(state) {
        return state.list.filter(item => !item.done).length
      },  
      isClearShow(state) {
        return state.list.some(item => item.done)
      }
    }
    
  • 使用 mapGetters

    • todo-footer.vue 中 引入 : import { mapGetters } from "vuex";

    • 将 store 中的 getter 映射到局部计算属性

      computed: { ...mapGetters(["isFooterShow", "itemLeftCount", "isClearShow"]) }-

    • 使用

      • 以前通过属性 :
      • 现在通过辅助函数 :

mapMutations 辅助函数

# 写在 methods
# 映射
...mapMutations(["delTodo",   "updateTodo",   "changeState"]),  

 # 起别名 (防止当前所在的函数名和这个mutaions名一致,  会导致死循环)
...mapMutations({
    deltodo:  "delTodo",  
    updatetodo:  "updateTodo",  
    changestate:  "changeState"
}),   

# 以后使用  
  this.deltodo({id})  替代 :   this.$store.commit(‘delTodo‘,  { id })

mapActions 辅助函数

# 写在 methods
# 映射
...mapActions(["asyncDelTodo"]),  
# 起别名    
    ...mapActions({
        aDT:  "asyncDelTodo"
    }),  
        
# 使用别名
  this.aDT({ id }); 
# 如果没有起别名
 this.asyncDelTodo({ id });  替换  this.$store.dispatch(‘asyncDelTodo‘,  {id})

技术图片


App.vue


main.js

import Vue from ‘vue‘
import App from ‘./App.vue‘
// 引入css
import ‘./assets/base.css‘
import ‘./assets/index.css‘
// 引入 仓库
import store from ‘./store/store.js‘

Vue.config.productionTip = false

new Vue({
    store,
    render: h => h(App)
}).$mount(‘#app‘)

//演示跨域
import axios from ‘axios‘

// https://douban.uieee.com/v2
// https://locally.uieee.com/categories
axios.get(‘/myapi/movie/in_theaters‘).then(res => {
    console.log(res)
})


store.js

// 引入 vuex
import Vue from ‘vue‘
import Vuex from ‘vuex‘

//装
Vue.use(Vuex)

// 抽离 state
const state = {
    list: [
        { id: 1, name: ‘吃饭‘, done: true },
        { id: 2, name: ‘睡觉‘, done: false },
        { id: 3, name: ‘打死春春‘, done: false }
    ]
}

// 抽离 mutations
const mutations = {
    // 添加任务
    addTodo(state, payload) {
        const id =
            state.list.length === 0 ? 1 : state.list[state.list.length - 1].id + 1
        // 添加
        state.list.push({
            id,
            name: payload.name,
            done: false
        })
    },
    // 删除任务
    delTodo(state, payload) {
        // setTimeout(() => {
        state.list = state.list.filter(item => item.id != payload.id)
        // }, 0)
    },
    // 修改状态
    changeState(state, payload) {
        //1. 根据id 查找当前的任务
        let todo = state.list.find(item => item.id == payload.id)

        //2. 状态取反
        todo.done = !todo.done
    },
    // 修改任务名称
    updateTodo(state, payload) {
        //1. 根据id找到对应的任务
        let todo = state.list.find(item => item.id == payload.id)
        //2. 修改任务
        todo.name = payload.name
    },
    // 清除完成
    clearCompleted(state) {
        // 过滤出来未完成的,重新赋值list
        state.list = state.list.filter(item => !item.done)
    }
}

// 抽离 getters (计算属性)
const getters = {
    // 底部的显示与隐藏
    isFooterShow(state) {
        return state.list.length > 0
    },
    // 剩余未完成的个数
    itemLeftCount(state) {
        return state.list.filter(item => !item.done).length
    },
    // clearCompleted 的显示与隐藏
    isClearCompletedShow(state) {
        return state.list.some(item => item.done)
    }
}

// 抽离 actions
const actions = {
    // 参数1 : context,类似store,所以有的人直接写store
    // 参数2 :
    asyncDelTodo(context, payload) {
        setTimeout(() => {
            context.commit(‘delTodo‘, payload)
        }, 0)
    }
}

// 实例化 仓库
const store = new Vuex.Store({
    // 严格模式
    strict: true,
    state,
    mutations,
    getters,
    actions
})

// 导出仓库
export default store


todoHeader.vue


import { loadavg } from ‘os‘;

todoList.vue




---


## todoFooter.vue
```html



笔记

初始化项目

  1. 安装脚手架 : npm i @vue/cli -g

  2. 创建项目 : vue create vuex-todos

    默认

  3. 运行项目 : npm run serve

  4. 把没用的删除


把 todos 模板拿过来

  1. 拷贝 模板中
  2. 拷贝 node_modules > base.css/index.css
  3. 在 main.js 中引入 css

组件化 改造

  1. 创建 todoHeader.vue 把 头部标签代码拷贝过去
  2. 引入组件
  3. 注册组件
  4. 使用组件

配置 vuex

  1. 安装 : npm i vuex

  2. 创建 文件 store.js

    router/router.js
    store/store.js

  • 引入
  • 实例化 store
  • 导出
  1. 挂载到 vue 实例上
  2. 准备数据 list

列表展示

  1. v-for 遍历
  2. 处理名称
  3. 处理选中状态
  4. 处理横线

添加任务

抽离 state 和 mutations

删除任务

修改任务

  1. 显示编辑状态
  2. 编辑任务
  3. 隐藏编辑状态

修改状态

底部显示与隐藏 + 剩余未完成个数 + 是否显示清除完成

  1. 使用 getters 类似 vue 的计算属性
  2. 使用 : v-show=‘$store.getters.isFooterShow‘

清除完成的


actions

mutations 里面不能放异步操作
异步操作应该放在 actions

  1. actions 里面可以放任意异步操作
setTimeout(() => {
  console.log(‘我是异步的咋地地‘)
}, 0)
  1. actions 不能直接修改状态 , 提交 mutations
 asyncDelTodo(context, payload) {
    setTimeout(() => {
      context.commit(‘delTodo‘, payload)
    }, 0)
  }

几个辅助函数

辅助函数 1-mapGetters

mapGetters 简化 getters
store里面的getters属性 映射到当前组件内的计算属性

  1. 第一步 : import { mapGetters } from ‘vuex‘
  2. 第二步 :
computed : {
  ...mapGetters([‘isFooterShow‘,‘XXXXX‘])
}
  1. 第三步 :使用
v-show=‘isFooterShow‘

辅助函数 2-mapMutations

简化 mutaions

  1. 引入 import { mapMutations } from ‘vuex‘
  2. 映射
methods : {
  ...mapMutations([‘delTodo‘]),
  ...mapMutations({
    deltodo :‘delTodo‘
  })
}
  1. 使用
this.deltodo({ id })

辅助函数 03-mapActions

简化 actions
将 store> actions 里面的方法 , 映射到当前组件内的方法

  1. 引入
  2. 映射
  3. 使用

跨域问题

  1. jsonp (只能用在 get)
  2. CROS (后台配合我们)
  3. 反向代理
// 接口
https://douban.uieee.com/v2/movie/in_theaters
module.exports = {
  devServer: {
    proxy: {
      ‘/myapi‘: {
        target: ‘https://douban.uieee.com/v2‘,
        pathRewrite: { ‘^/myapi‘: ‘‘ },

        // 设置https
        secure: false,
        // 必须设置该项
        changeOrigin: true
      }
    }
  }
}

438 vuex:基本使用,传参,vue和vuex的配合使用,Vue脚手架3,使用Vuex改版 TodoMVC,actions,mapGetters,mapMutations,mapActions

标签:集中式   包含   获取数据   tle   dos   todo   更新   scl   document   

原文地址:https://www.cnblogs.com/jianjie/p/12689679.html


评论


亲,登录后才可以留言!