flux读取不到数据_初学flux的疑问?无法添加数据到DOM

我初学flux,照着网上的代码,尝试学习写了一个简单的添加数据表页面,如图:

我想实现的功能是在下方表单填写数据之后点击提交可以实时的在上方表格添加一条数据,现在碰到的问题是我点击提交毫无反应也没有报错。我的架构是这个样子的:

我试了几遍不知道问题在哪,我的表格和表单是分成两个组件的:

表单组件如下:

var React = require('react');

var FormAction = require('../actions/form-action');

var FormGroup = React.createClass({

_onSubmit: function(){

var name = this.refs.name.value,

age = this.refs.age.value,

job = this.refs.job.value,

data = {name: name, age: age, job: job};

FormAction.createComment({data: data});

},

render: function(){

return (


Name

Age

Job

提交

);

}

});

module.exports = FormGroup;

表格组件如下:

var React = require('react');

var FormGroup = require('./form-group');

var TableStore = require('../stores/table-store');

function getStateStore(){

return {

items: TableStore.getAll()

}

}

var TableApp = React.createClass({

getInitialState: function(){

return {items: TableStore.getAll()}

},

componentDidMount: function(){

TableStore.addChangeListener(this._onChange());

},

componentWillUnmount: function(){

TableStore.removeChangeListener(this._onChange());

},

_onChange: function(){

this.setState({items: TableStore.getAll()});

},

render: function(){

var items = this.state.items;

var itemHtml = items.map(function(item, i){

return (

{item.name}{item.age}{item.job}

);

});

return (

姓名年龄职业

{itemHtml}

);

}

});

module.exports = TableApp;

stores的代码如下:

var AppDispatcher = require('../dispatcher/app-dispatcher');

var $ = require('jquery');

var items = [];

var TableStore = {

getAll: function(){

return items;

},

addNewItem: function(data){

items.push(data);

},

emitChange: function(){

$(this).on('change');

console.log(items);

},

addChangeListener: function(callback){

$(this).bind('change', callback);

},

removeChangeListener: function(callback){

$(this).unbind('change', callback);

}

};

AppDispatcher.register(function(action) {

switch(action.actionType) {

case 'CREATE_COMMENT':

TableStore.addNewItem(action.data);

TableStore.emitChange();

break;

default:

}

});

module.exports = TableStore;

其他代码应该不具有参考价值了,想问一下大神这是为什么,想了半天也试了半天还是没搞出来,谢谢了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574823.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

列表视图

列表视图 分类: SharePoint入门2014-10-14 00:10 298人阅读 评论(0) 收藏 举报SharePointlist view使用View,可以按照特定的要求和条件展示List/Library里面的条目。View可以做一下设定来显示数据: 1. 显示哪些属性(column) 2. 属性…

android 线程 界面,android开发教程之子线程中更新界面

每个Handler对象与创建它的线程相关联,并且每个Handler对象只能与一个线程相关联。Handler一般有两种用途:1)执行计划任务,你可以再预定的实现执行某些任务,可以模拟定时器。2)线程间通信。在Android的应用启动时,会创…

vue怎么让接口带上cookie_在Vue中如何使用Cookie操作实例

大家好,由于公司忙着赶项目,导致有段时间没有发布新文章了。今天我想跟大家谈谈Cookie的使用。同样,这个Cookie的使用方法是我从公司的项目中抽出来的,为了能让大家看懂,我会尽量写详细点。废话少说,我们直…

python 简历处理_按照这个方式学Python,老板把垃圾桶里的简历舔回来:月薪50000...

对于Python相信很多人都不陌生,相较于Excel、Tableau、PowerBI等普通的数据分析工具来说,Python的优势显然要大很多。Python有很多优点,如果你能很好的运用到工作中,会发现工作效率大大提升,涨薪也是再正常不过的事情。…

鸿蒙系统下载 绿色,PGWARE PcMedik

pcmedik,一款可以优化你的电脑,让pc发挥更大的性能,大大减少死机的事件。pcmedik操作简单,其优化过程只需三个步骤:①选择一个本机当前正在使用的操作系统。②选择本机使用的cpu类型。③点击[优化&#xff…

attr和prop区别

今天写了个小程序,获取input[checked]属性,$(#check1).attr(checked),结果返回undefined,查询了一番, 如果是具有true和false两个属性值的属性 如checked selected 或者disabled获取该属性值要用prop()返回boolean值&a…

html5视频抓取,js和HTML5基于过滤器从摄像头中捕获视频的方法

这篇文章主要介绍了jsHTML5基于过滤器从摄像头中捕获视频的方法,涉及javascript基于html5元素操作多媒体的使用技巧,需要的朋友可以参考下本文实例讲述了jsHTML5基于过滤器从摄像头中捕获视频的方法。分享给大家供大家参考。具体如下:index.html页面:Nat…

Android Audio Play Out Channel

1: 7嘴8舌 扬声器, 耳机, 和听筒 就是通过: audiomanager.setmode(AudioManager.MODE_IN_COMMUNICATION)audiomanager.setSpeakerhponeOn(boolean value).这两个来设置.不过有的好像不支持的. 米手机上切换 扬声器和听筒不能切换 Android AudioTrack音频播放分析 音频资源在播…

c html转换成word,C#实现HTML转WORD及WORD转PDF的方法

本文实例讲述了C#实现HTML转WORD及WORD转PDF的方法。分享给大家供大家参考。具体如下:功能:实现HTML转WORD,WORD转PDF具体代码如下:using System;using System.Collections.Generic;using System.ComponentModel;using System.Dat…

bootstrap下拉框分页_【Bootstrap】 bootstrap-select2下拉菜单插件

这次开发了个小TRS系统,虽然是很小,但是作为初心者,第一次用到了很多看起来洋气使用起来有相对简单的各种前端(主要是和bootstrap配合使用)组件。包括bootstrap-select2,bootstrap-datetimepicker,bootstrap-fileinput…

Java-eclipse快捷键及设置

CtrlD: 删除当前行 CtrlAlt↓ 复制当前行到下一行(复制增加) CtrlAlt↑ 复制当前行到上一行(复制增加) Alt↓ 当前行和下面一行交互位置(特别实用,可以省去先剪切,再粘贴了) Alt↑ 当前行和上面一行交互位置(同上) Alt← 前一个编辑的页面 Alt→ 下一个编辑的页面(当然是针对上…

html 网页主题设置吗,如何使用css样式对html页面进行背景设置呢?

摘要:下文讲述css样式对html页面的背景色、背景图片进行相关设置的方法分享,如下所示:在html中,定义元素的背景信息,可以采用以下css属性,如下所示:css属性功能background在此属性中,我们将所有的背景设置都放入此属性值中backgro…

redis 缓存 @class: 会有 $hibernateproxy_微信亿级在线点赞系统,用Redis如何实现?

点赞功能大家都不会陌生,像微信这样的社交产品中都有,但别看功能小,想要做好需要考虑的东西还挺多的,如海量数据的分布式存储、分布式缓存、多 IDC 的数据一致性、访问路由到机房的算法等等。图片来 Pexels本文介绍大型社交平台点…

Xcode怎样调整模拟器大小

快捷键: Command 1:显示100%大小 Command 2:显示50%大小(默认)转载于:https://www.cnblogs.com/xiaofeng6636/p/4311753.html

查询hive表_大数据中Hive与HBase的区别与联系

二者区别Hive:Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供简单的sql查询功能。Hive本身不存储和计算数据,它完全依赖于HDFS和MapReduce,Hive中的表纯逻辑。hive需要用到hdfs…

查询使用NoLock

当我们在操作数据库的时候,无论是查询还是修改数据库的操作我们都习惯使用using(var dbnew XXXDB()){},但是如果仅仅是做查询,最好是使用NoLock,因为NoLock使用的是共享锁,可以减少死锁发生的机率。 从上图中代码可以看…

端午粽香html5游戏,《快乐端午粽飘香》亲子活动教案

《快乐端午粽飘香》亲子活动教案过端午节是我国两千多年来的习惯,为了让幼儿更好地了解端午节,感受端午节丰富的文化内涵,激发初步的爱国主义情感,丰富生活经验,应届毕业生考试网小编特意为大家整理了《快乐端午粽飘香…

d3js绘制y坐标轴_【ggplot2】 设置坐标轴

基本箱线图library(ggplot2)bp ggplot(PlantGrowth, aes(xgroup, yweight)) geom_boxplot()bp反转 x轴 与 y轴bp coord_flip()离散型数据的坐标轴改变坐标轴中各项目的顺序 > 特别注意, 离散数据的坐标轴中数据做为 factor 变量处理,他的位置取决于 level的顺序# 手动设置…

html5点击视频跳转,javascript – 播放后重定向html5视频

我有一个html 5视频,我删除了控制按钮并添加了一个js代码,以便用户在点击视频时播放视频.我需要做的是绑定一个额外的脚本,在播放视频后重定向页面而不重新加载页面.下面是我的js代码.function play(){var video document.getElementById(video);video.addEventListener(click…

setInterval

定义和用法: setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式。 setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法…