之前也看了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. EAN13条码的校验位的Excel算法

    校验位原公式: 单元格=10-RIGHT(SUM(MID($B3,{1;2;3;4;5;6;7;8;9;10;11;12},1)*{1;3;1;3;1;3;1;3;1;3;1;3})) 简化公式: 单 ...

  2. USB接口外壳地和信号地间的处理

    USB外壳地和信号地之间串接1M电阻,并且还接一个0.01uf的电容到信号地,能否将一下这样处理的原理和目的: 1.将影响外壳的噪音滤除,不影响信号地: 2.迫使板子上电流是流入内部的信号地,而不是流 ...

  3. 二、Spring Boot系列:Spring Initializer快速创建Spring Boot项目

    1.点击创建新工程 2.选择Spring Initializer和jdk1.8 注意:项目名称要小写字母 3.现在只需要一个创建一个web,选择一个就好 4.没有用的文件,可以删除 5.pom.xml ...

  4. 10.整合email

    整合email <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...

  5. redisTemplate 封装bitcout

    @Repositorypublic class RedisServiceExtend { @Autowired private RedisTemplate<String, String> ...

  6. Fiddler的详细介绍

    Fiddler的详细介绍 一.Fiddler与其他抓包工具的区别 1.Firebug虽然可以抓包,但是对于分析http请求的详细信息,不够强大.模拟http请求的功能也不够,且firebug常常是需要 ...

  7. 【leetcode】592. Fraction Addition and Subtraction

    题目如下: 解题思路:本题考察的是分数的加减法.小学时候就学过,分数的加减法是先求两个分母的最小公倍数,然后分子分别乘以最小公倍数与自己分母的商,相加后约分即可.所以,本题只要按+,-两个符号分割输入 ...

  8. 【QUIC】Quick UDP Internet Connections

    QUIC(Quick UDP Internet Connections,快速UDP互联网连接)是Google提出的一种基于UDP改进的通信协议,其目的是降低网络通信的延迟,提供更好的用户互动体验. Q ...

  9. 某些 UI效果 实现思路

    一.日历组件: https://blog.csdn.net/amork/article/details/7257212 二.瀑布流 三.轮播图:轮播图已经用的很多了,结构也简单就不去将了. 四.分页组 ...

  10. AsyncTask2

    参考: AsyncTask - 简书http://www.jianshu.com/p/3b839d7a3fcf 前言 在android应用开发过程中,我们需要是时刻注意保证应用程序的稳定和UI操作响应 ...