1、创建src/store/index.js----仓库所在地----暴露store
2、main.js入口文件处引入store,挂载到Vue根实例中
3、创建store/movie.js-----电影页面对应的状态管理模块
export default {
state: {
},
getters: {
},
actions: {
},
mutations: {
}
}
4、定义电影页面关联的初始状态
export default {
state: {
movielist: []
},
getters: {
},
actions: {
},
mutations: {
}
}
5、定义异步操作action和改变状态mutation
export default {
state: {
movielist: []
},
getters: {
},
actions: {
getMovielist ({commit}) {
}
},
mutations: {
changeMovielist (state, data) {
state.movielist = data
}
}
}
6、实现异步操作中的数据请求-----src/api/movie.js
import axios from 'axios'
export default {
getMovielist (cb) {
// .then(({data}) => {cb(data)})
.then((res) => {cb(res.data)})
.catch((err) => {console.log(err)})
}
}
7、实现store/movie.js中的action的后续操作-----提交mutation改变数据源
import movieapi from '@/api/movie.js'
export default {
state: {
movielist: []
},
getters: {
},
actions: {
// getMovielist ({commit}) {
// movieapi.getMovielist((data) => {commit('changeMovielist', data)})
// },
getMovielist (context) {
movieapi.getMovielist((data) => {context.commit('changeMovielist', data)})
}
},
mutations: {
changeMovielist (state, data) {
state.movielist = data
}
}
}
8、组件movie组件的js中,添加一个选项computed,用来接收store中的数据----使用mapState辅助函数
import {mapState} from 'vuex'
export default {
computed: { //你store/movie中定义的初始状态是什么,key值就是什么,中间{}中的store/index.js中的modules中的key值
...mapState({
movielist: ({movie}) => movie.movielist
})
}
}
9、提交action---组件mounted函数中
import {mapState} from 'vuex'
export default {
computed: { //你store/movie中定义的初始状态是什么,key值就是什么,中间{}中的store/index.js中的modules中的key值
...mapState({
movielist: ({movie}) => movie.movielist
})
},
mounted () {
this.$store.dispatch('getMovielist')
}
}
10、组件的模板中可以直接使用movielist渲染数据
<ul>
<li v-for='item in movielist' :key='item.id'>
{{item.title}}
</li>
</ul>
11、分页功能
casts组件中添加了一个按钮,模拟下一页
<button @click="getData()">下一页</button>
在其js中添加
methods: {
getData () { //下一页
this.$store.dispatch('getCastsPagingList',{skipNum:2,limitNum:5})
}
},
store/casts.js
actions: {
getCastsList (context) {
castsapi.getCastsList((data) => {
context.commit('changeCastslist', data)})
},
getCastsPagingList (context, option){
castsapi.getCastsPagingList(option, (data) => {
context.commit('changeCastsPagingList', data)})
}
},
mutations: {
changeCastslist (state, data) {
state.castslist = data
},
changeCastsPagingList (state, data) {
state.castslist = [...state.castslist, ...data]
}
}
}
api/casts.js
import axios from 'axios'
export default {
getCastsList (cb) {
.then(({data}) => {cb(data)})
.catch((err) => {console.log(err)})
},
getCastsPagingList ({limitNum, skipNum}, cb) {
console.log(limitNum)
console.log(skipNum)
.then(({data}) => {cb(data)})
.catch((err) => {console.log(err)})
}
}
- 浅谈vuex使用方法(vuex简单实用方法)
Vuex 是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.Vuex 也集成到 Vu ...
- vuex - 简单使用步骤梳理,轻松掌握、附源码
-----------------------往期----------------------------- vuex - 学习日记 vuex - 辅助函数学习 vuex - 常用命令学习及用法整理 ...
- vue - vue + vue-router + vuex 简单项目
简单的,我的首页,我的笔记项目 vue + vue-router + vuex View + VM(ViewModel) + Model (webpack) vue init webpack lint ...
- vuex简单示例
一.vuex是什么,解决了什么问题? 官方解释是:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生 ...
- (转)Vuex简单入门
今天试了一下Vuex,感觉跟Redux的实现思想类似.再此,简单地总结一下. 什么是Vuex 在Vue中,多组件的开发给我们带来了很多的方便,但同时当项目规模变大的时候,多个组件间的数据通信和状态管理 ...
- 转一篇关于vuex简单理解的文章
学习vuex半天摸不着头脑无意间发现了这篇文章 对vuex做了一个简单的阐述比较有助于我的理解 现在分享出来希望能给一些朋友一点帮助 这个是原文地址 http://www.ituring.com.c ...
- Vue + Vuex 简单使用
我们要实现的很简单,就是点击+1的count加一,点击-1的时候count-1 一.mutation 在vue 中,只有mutation 才能改变state. mutation 类似事件,每一个mu ...
- Vue状态管理Vuex简单使用
状态管理保存在store\index.js中,简单说明如下 import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export def ...
- 使用vuex简单的实现系统中的状态管理
最近项目中用到了vue,其中状态的集中管理使用到了vuex,因此就学习vuex做一个简单的记录.vuex的官方网址如下: https://vuex.vuejs.org/zh-cn/ vuex 当我们 ...
随机推荐
- python 全局变量
修改全局变量 name = 'jason' def change_name(): global name name = 'Jason'
- Python学习笔记6函数和代码复用
1.函数 (1)定义: (2)函数调用 (3)函数的参数传递 参数传递的两种方式:函数调用时,参数可以按照位置或名称的方式传递 (4)函数的返回值 (5)局部变量和全局变量 (6)lambda函数 2 ...
- Hillstone设备管理-恢复出厂设置
1.CLI命令行操作 unset all: 根据提示选择是否保存当前配置y/n: 选择是否重启y/n: 系统重启后即恢复到出厂设置. 2.webUI操作 “系统”—“配置”,点击“清除”按钮,系统会提 ...
- ASP.NET Core下发布网站图解
与ASP.NET时代不同,ASP.NET Core不再是由IIS工作进程(w3wp.exe)托管,而是使用自托管Web服务器(Kestrel)运行,IIS则是作为反向代理的角色转发请求到Kestrel ...
- Curl测试socks5 or http 代理命令
测试socks5命令:curl --socks5 125.119.175.48:8909 http://example.com/ 测试http命令: curl --connect-timeout 2 ...
- import os, glob, fnmatch--Python os/glob/fnmatch主要函数总结
auther: Lart date: 2019-01-17 update: 2019-01-18 09:55:36 --- import os, glob, fnmatch 针对某些操作, 官方推荐这 ...
- ICSE 2018 论文
仅简单分析自己感兴趣的论文. 9.6 Million Links in Source Code Comments: Purpose, Evolution, and Decay 分析了 source c ...
- python基础之Day20part1
一.hash算法 什么是hash? 类似工厂加工的过程,传bytes串,经过运算返回字符 hash相当于工厂,传给hash算法的内容是原材料,hash值为产品 为何用hash? hash三大特性: 1 ...
- mr实现pagerank
PageRank计算什么是pagerankPageRank是Google专有的算法,用于衡量特定网页相对于搜索引擎索引中的其他网页而言的重要程度.是Google创始人拉里·佩奇和谢尔盖·布林于1997 ...
- 第二阶段第七次spring会议
昨天我将尝试对软件进行添加搜索引擎的界面. private void linkLabel1_LinkClicked_1(object sender, LinkLabelLinkClickedEvent ...