之前也看了vuex的文档,对它的原理只是了解,看代码(仅自己复习、做笔记)

流程是在组件的created中提交dispatch,然后通过action调用一个封装好的axios然后再触发mutation来提交状态改变state中的数据,然后在组件的计算属性中获取state的数据并渲染在页面上。

state   //date

mutations   //computed

actions   //methods

mock.js文件   模拟user列表

/*user列表*/
Mock.mock('/api/getUserInfo','post', {
"data|10-20": [
{
"_id": /\d{9}/,
"date": Random.date('yyyy-MM-dd'),
"name": "@cname",
"address": Random.city(true),
"sex|1": [
"男",
"女"
]
}
]
})

目录结构:

fetch /api.js主要是请求数据的,这个可以看情况而定,我觉得是多余了,暂时还没有更改

用的vuex的模块化处理,这样感觉高效,适用与大型项目,这里就不一一陈述用法,就是简单的配置,然后将文件导出放在index.js文件里(出口文件?)

fetch/api.js

import axios from 'axios'

export function fetch(url,params) {
return new Promise((resolve, reject) => {
axios.post(url, params)
.then(res => {
console.log('api---ok');
console.log(res.data)
resolve(res.data)
})
.catch((error) => {
console.log(error)
reject(error)
})
})
}
export default {
getList() {
console.log('进入api.js')
return fetch('/getUserInfo') //这是我user的mock模拟的接口
}
}

userList.js

import api from './../../fetch/api'
const userList = {
state: {
userListData: [],
},
mutations: {
SET_DATELIST:(state,res) => {
console.log('进入mutations');
console.log(res)
state.userListData = res.data
console.log(state.userListData)
},
},
actions: {
getList({ commit, state }){
console.log('进入action');
api.getList().then(res =>{
console.log('axios中调用封装后的axios成功');
commit('SET_DATELIST', res)
})
}
},
getters: {}
}; export default userList

然后再页面中使用,这里我用了...Map

<template>
<el-table :data="userListData" height="450" border style="width: 100%">
<el-table-column prop="_id" label="id" width="180"></el-table-column>
<el-table-column prop="date" label="注册日期" width="180"></el-table-column>
<el-table-column prop="name" label="用户姓名" width="180"></el-table-column>
<el-table-column prop="sex" label="性别" width="180"></el-table-column>
<el-table-column prop="address" label="注册地址"></el-table-column>
</el-table>
</template> <script>
import { mapState, mapActions } from 'vuex';
export default {
name: 'userList',
data() {
return {
// userListData: []
}
},
// methods:{
// getList(){
// this.$axios.post('/getUserInfo').then( res => {
// console.log(res);
// this.userListData = res.data
// })
// }
// },
// created: function () {
// this. getList();
// }
created() {
this.$store.dispatch('getList'); //提交siapatch
},
computed: {
...mapState({
userListData: state => state.userList.userListData /*从vuex中获取到数据*/
})
}
}
</script> <style scoped>
.el-row{
margin:20px auto;
}
</style>

然后就可以在页面展示了,这里写这个的目的是想让自己加深对vuex触发的流程更加熟悉,里面有很多打印,可以加深理解。

vuex存取数据展示在table里-----第一次实现的更多相关文章

  1. bootstrap table通过ajax获取后台数据展示在table

    1. 背景 bootstrap table 默认向后台发送语法的dataType为 json,但是为了解决跨域问题我们需要将dataType改为jsonp,这时就需要修改bootstrap table ...

  2. 为什么Vuex内数据改变了而组件没有进行更新?

    这两天在进行一个首页的制作,结果就碰到了标题上所述的问题了,用了一天的时间在网上查资料.终于找出了问题所在 Vuex的数据写在store里,在组件中需要用到this.$store.commit() 来 ...

  3. 使用C#或javascript将Table里的数据导出到Excel

    原文:使用C#或javascript将Table里的数据导出到Excel Demo效果图: 用C#将Table数据导出Excel: 本方法已经将导出excel做成分部视图,引用时只需在视图中使用如下代 ...

  4. django学习-27.admin管理后台里:对列表展示页面的数据展示进行相关优化

    目录结构 1.前言 2.完整的操作步骤 2.1.第一步:查看ModelAdmin类和BaseModelAdmin类的源码 2.2.第二步:查看表animal对应的列表展示页面默认的数据展示 2.3.第 ...

  5. LigerUI之Grid使用详解(三)——字典数据展示

    一.问题概述 在开发web信息管理系统时,使用Web前端框架可以帮助我们快速搭建一组风格统一的界面效果,而且能够解决大多数浏览器兼容问题,提升开发效率.在关于LigerGrid的前两篇的内容里,给大家 ...

  6. 手把手教你写带登录的NodeJS爬虫+数据展示

    其实在早之前,就做过立马理财的销售额统计,只不过是用前端js写的,需要在首页的console调试面板里粘贴一段代码执行,点击这里.主要是通过定时爬取https://www.lmlc.com/s/web ...

  7. hugegraph 数据存取数据解析

    hugegraph 是百度开源的图数据库,支持hbase,mysql,rocksdb等作为存储后端.本文以EDGE 存储,hbase为存储后端,来探索是如何hugegraph是如何存取数据的. 存数据 ...

  8. EasyUI-datagrid数据展示+MongoDB数据操作

    使用EasyUI-datagrid进行数据展示:进行添加,修改,删除操作逻辑代码,数据源来自MongoDB. 一.新建SiteInfo控制器,添加Index页面:http://www.cnblogs. ...

  9. 【助教】Java获取数据库数据展示

    本文将给出一个最简单的Java查询数据库中一张表的数据并将查询结果展示在页面的例子. 实际上,我们要解决以下两个问题: Java与数据库交互(以JDBC为例) 数据展示在前台页面(以Servlet+J ...

随机推荐

  1. jenkins部署的零碎知识

    环境要求 1)版本控制子系统(SVN):SVN服务器.项目对应版本库.版本库中钩子程序(提交代码后,触发Jenkins自动打包并部署到应用服务器)(2)持续集成子系统(存在Jenkins的服务器):J ...

  2. vue,一路走来(10)--生产环境

    生产环境下的一些问题 使用webpack 打包前端应用后,图片和css.js 资源引用会出问题,这源于开发环境的目录和生产环境的路径[url]不同 比如,开发环境的url是:http://localh ...

  3. springboot使用异步查询数据

    主要适用于需要查询多种类型的数据,而且二者的参数没有关联的情况. 1.开启异步调用注解 2.创建抽象类,定义相关方法 /** * @author:YZH * time: 2019/8/8 12:16 ...

  4. ARC062F AtCoDeerくんとグラフ色塗り / Painting Graphs with AtCoDeer Burnside 引理

    题目传送门 https://atcoder.jp/contests/arc062/tasks/arc062_d 题解 首先对整张图做 Tarjan 点双. 对于一个点双,如果是由一条边构成的,那么很显 ...

  5. List和Tuple的中的method对比

  6. boost Filesystem

    The library Boost.Filesystem makes it easy to work with files and directories. Paths Paths can be bu ...

  7. 回炉Spring--事务及Spring源码

    声明式事务 配置文件信息: /** * @EnableTransactionManagement 开启基于注解的事务管理功能 * 1.配置数据源 * 2.配置事务管理器来管理事务 * 3.给方法上标注 ...

  8. macOS 和 Linux 的内核区别

    有些人可能会认为 macOS 和 Linux 内核之间存在相似之处,因为它们可以处理类似的命令和类似的软件.有些人甚至认为苹果公司的 macOS 是基于 Linux 的.事实上是,两个内核有着截然不同 ...

  9. ip地址与子网掩码----基础知识

    前言 IP地址有三种基本类型,由网络号的第一组数字来表示. A类地址的第一组数字为1-126. B类地址的第一组数字为128-191. C类地址的第一组数字为192-223. 注:数字0和 127不作 ...

  10. spring boot项目打包成war

    一.修改打包类型 在pom.xml中修改 <packaging>war</packaging> 二.移除嵌入式tomcat插件,并以依赖方式引入 <dependency& ...