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 当我们 ...
随机推荐
- 使用css3实现动画来开启GPU加速
参考文章: https://www.w3cplus.com/css3/introduction-to-hardware-acceleration-css-animations.html http:// ...
- 20175314薛勐 MyOD(课下作业,选做)
MyOD(课下作业,选做) 要求 编写MyOD.java 用java MyOD XXX实现Linux下od -tx -tc XXX的功能 思路 伪代码: 读取命令行输入的参数(文件名) 以16为每个字 ...
- 20175314薛勐 MyCP(课下作业,必做)
MyCP(课下作业,必做) 要求 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数: java MyCP -tx XXX1.txt XXX2.bin ...
- Django中把SQLite数据库转换为Mysql数据库的配置方法
我们在学习和开发Django的时候,一般是使用SQLite作为数据库.在正式讲网站部署上线是用MySQL数据库比较多.MySQL支持高并发的访问,而且相对于SQLite,MySQL性能更好.下面讲讲如 ...
- 4-18 class与id的区别
1. class是设置标签的类, class属性用于指定元素属于何种样式的类. 如样式表可以加入.content1 { color: red; background: #ff80c0 } 使用方法:c ...
- MySQL千万级数据库查询怎么提高查询效率
在实际项目中,当MySQL表的数据达到百万级别时候,普通查询效率直线下降,而且当使用的where条件较多,其查询效率是让人无法容忍的.假如一个taobao订单查询详情要几十秒,可想而知的用户体验是多差 ...
- return this 和return * this
this是指向自身对象的指针,*this是自身对象. 也就是说return *this返回的是当前对象的克隆或者本身(若返回类型为A, 则是克隆, 若返回类型为A&, 则是本身 ). retu ...
- css伪类及伪元素用法
注:该表引自W3School教程 伪元素的分类及作用: 接下来让博主通过一些生动的实例(之前的作业或小作品)来说明几种常用伪类的用法和效果,其他的读者可以自己尝试: :active 大致效果为用鼠标 ...
- 数据库子查询和join的比较
子查询进行SELECT语句嵌套查询,可以一次完成很多逻辑上需要多个步骤才能完成的SQL操作.子查询虽然很灵活,但是执行效率并不高. select goods_id,goods_name from go ...
- 静态链接库与动态链接库----C/C++
http://blog.csdn.net/freestyle4568world/article/details/49817799