页面效果图:

数据操作分析:

  1. 在查询表组件的  TableData.js 中操作如下内容:
    1. 给每一行绑定一个checkbox,且在点击这个 checkbox 时,触发 action 中的一个方法(formatPostCollectionList),这个方法是用来更新选中的实体数组。formatPostCollectionList为action中的方法,需要export
      1. 定义每一行的实体为一个数组,用变量 postCollections 表示
      2. 如果选中当前行,则更新实体数组中的数据;如果取消当前行,则删除实体中的数据;
      3. 参数为  row  ;
    2. 点击删除按钮后,使用 componentDitUpdate() 生命周期方法,在组件更新后调用。
      1. 如果删除成功,则执行 action 中的方法 clearPostCollection()。这个方法是用来清空当前行实体中的数据;
      2. 如果删除成功,最后执行  查询表的刷新重新加载数据的方法
  2. 更新实体数据与清空实体数据的方法,在 action 中执行。

代码分析:

  1. 表查询操作
    1. 调查询接口,Api中的方法
      1. searchPostCollectionByActivityId(activityId, callback) {
        const queryParam = `/tob/post/search?activeId=${activityId}`; //接口,使用``可以在URL中显示查询参数
        Config.get(queryParam, callback);
        }
    2. action中操作查询数据的方法  postCollectionEntityList 存放接口中的所有数据
      1. export function initPostCollection(row){
        return (dispatch, getState) => {
        let activityId = row.activityId;
        Api.searchPostCollectionByActivityId(activityId, params => {
        dispatch(initPostCollectionSetter(activityId,params));
        });
        }
        }
        function initPostCollectionSetter(activityId,params){
        return {
        type:INIT_POST_COLLECTION,
        activityId:activityId,
        data:{postCollectionEntityList:params}
        }
        }
    3. 3. TatleData 表组件中调用 action 的方法,至此 表数据 OK

      1. export default class TableData extends Component {
        constructor(props){
        super(props);
        } componentDidMount() {
        const param = this.props.queryData;
        console.log("param === " + param);
        this.props.initPostCollection(param);//action中获取接口数据的方法
        }
        render(){
           // 定义postCollectionEntityList中的数据
        let postCollectionEntityList = [
        {
        postCollectionName:'',
        postCollectionId:'',
        activityId:''
        }
        ];
        //判断,如果postCollectionEntityList中有数据,则把数据显示出来
        if (this.props.postCollectionState.postCollectionEntityList) {
        postCollectionEntityList = this.props.postCollectionState.postCollectionEntityList;
        console.log("postCollectionEntityList" + postCollectionEntityList);
        } //acb 表数据
        return(
        <div><TableExit data={postCollectionEntityList} acb={this.props.initPostCollection}>
        <TableCloumnsExit dataField="activityTitle">活动名称</TableCloumnsExit>
        <TableCloumnsExit dataField="postCollectionName">帖子集名称</TableCloumnsExit>
        <TableCloumnsExit dataField="postCollectionId">帖子集编号</TableCloumnsExit>
        <TableCloumnsExit dataField="active" dataFormat={this.postCollectionFormatter}>修改</TableCloumnsExit>
        <TableCloumnsExit dataField="send" dataFormat={this.activeFormatter.bind(this)}>发送</TableCloumnsExit>
        <TableCloumnsExit dataField="send" dataFormat={this.questionBankFormatter.bind(this)}>题库</TableCloumnsExit>
        </TableExit>
        </div>
        );
        }
        }
  2. 删除表数据操作
    1. 调删除接口,API中的方法
      1. deletePostCollections (activityId ,params, callback) {
        let path = `/tob/post/deletePostCollection/${activityId}`; //删除接口
        Config.deleteWithNoResponse(path ,params, callback);
        }
    2. action 中写删除数据的方法
      1. 删除实体
        1. 删除实体前要先 插入 checkbox
          1.  checkboxFormatter(cell,row) {
            return <input bsStyle="primary" type="checkbox"></input>
            }
        2. 查询表中使用 checkbox
          1. <TableCloumnsExit dataField="alter" dataFormat={this.checkboxFormatter.bind(this)}>选择</TableCloumnsExit>
        3. 点击 checkbox 会触发 更新选中的实体数据的方法
          1. checkboxFormatter(cell,row) {
            return <input bsStyle="primary" type="checkbox" onClick={this.props.formatPostCollectionList.bind(this,row)}></input>
            }
        4. 更新选中实体数据的方法,在action中编写
          1. export function formatPostCollectionList(row) {
            return(dispatch, getState) => {
            let postCollectionId = row.postCollectionId; //获取每一行的ID
            let state = getState().postCollectionState; //从postCollectionState()中拿到state并赋值给全局state
            let postCollections = state.postCollections; // 红色字体标注为实体中的数据容器
            let postCollectionItem = {
            postCollectionId:postCollectionId //实体中的数据ID
            };
            if (postCollections) { //postCollections 实体数据,可能 有数据
            let index = -1; // index = -1 指默认实体中没有数据
            for (let i = 0 ;i < postCollections.length ;i++) { //如果实体中有数据,则循环
            let postCollection = postCollections[i]; //拿实体中的数据,给变量postCollection
            let id = postCollection.postCollectionId; //从拿到的实体数据中,取每一个ID,方法对比(选中的数据与实体中的数据对比)
            if (postCollectionId == id) { //如果实体中的ID == 选中的ID
            index = i; //把实体中选中的的数据 赋值为 i
            }
            }
            if (index > -1) { //如果实体的数据存在,不为空
            postCollections.splice(index,1); //删除实体对象中index位置中的一个数据
            } else {
            postCollections.push(postCollectionItem); //如果实体数据为空,则push实体中的ID数据
            }
            } else {
            postCollections = []; // 第一次render时,实体数据可能为空 / 为undefined,那么将它定义为一个数组
            postCollections.push(postCollectionItem); //给这个空数组push数据
            }
            dispatch(formatPostCollectionListSetter(postCollections));
            }
            }
            function formatPostCollectionListSetter(params){
            return {
            type:SET_POST_COLLECTIONS,
            data:{postCollections:params} //红色变量为实体数据
            }
            }
        5. 选中实体数据后,点击删除按钮,会触发deletePostCollections  删除方法
        6. export const DELETE_POST_COLLECTIONS = 'DELETE_POST_COLLECTIONS';
          export function deletePostCollections(){ //点击删除按钮后,触发deletePostCollections删除方法
          return(dispatch, getState) => {
          let state = getState().postCollectionState;
          let activityId = state.activityId;
          let postCollections = state.postCollections; //实体对象从state中获取
          Api.deletePostCollections(activityId ,postCollections, params => { //调删除接口的方法
          dispatch(deletePostCollectionsSetter(params));
          });
          }
          }
          function deletePostCollectionsSetter(params){
          alertPre("",params);
          return {
          type:DELETE_POST_COLLECTIONS,
          data:{deletePostCollectionsResponse:params} //deletePostCollectionsResponse 选中的要删除的数据容器
          }
          }

          6. 把删除数据的方法绑定到删除按钮,绑定前根据删除钮钮的状态,判断是否可点击

        7. render(){
          let dis = true; //删除按钮状态,默认为禁用状态,返回为true
          let postCollections = this.props.postCollectionState.postCollections; //获取实体中的数据
          if (typeof(postCollections) == 'undefined' || postCollections.length == 0) { //如果实体中的数据为 undefined 或者 为空
          dis = true; //如果实体中没有数据,则按钮状态为禁用状态
          } else {
          dis = false; //如果实体中有数据,选中后的状态为可点击状态
          } const buttonsInstanceDel = (
          <ButtonToolbar className="mb10">
          <Button bsStyle="danger" disabled={dis} onClick={this.props.deletePostCollections}>删除贴子集</Button> //红色字体标为 删除数据的方法
          </ButtonToolbar>
          ); return(
          <div>
          {buttonsInstanceDel}
          </div>
          )
          }

          7.  删除成功后,调用生命周期的方法,在 表查询组件中,更新表数据。如果删除成功,则执行两个方法:清空实体数据与刷新加载数据

        8. componentDidUpdate () {
          let deletePostCollectionsResponse = this.props.postCollectionState.deletePostCollectionsResponse; //deletePostCollectionsResponse 删除的数据
          if (typeof(deletePostCollectionsResponse) != 'undefined') { //如果这个数据类型不是 undefined
          let status = deletePostCollectionsResponse.status; //获取到这个删除的数据状态
          if (200 == status) { //如果为200,删除成功
          this.props.clearPostCollection(); //加载清空实体数据的方法 clearPostCollection,就是从实体数据中删除被删除的数据
          let param = {
          activityId:this.props.postCollectionState.activityId
          }
          this.props.initPostCollection(param); //根据ID重新加载剩余的数据
          }
          }
          }
      2. 清空实体
        1. export const CLEAR_POST_COLLECTION = 'CLEAR_POST_COLLECTION';
          export function clearPostCollection(){
          return {
          type: CLEAR_POST_COLLECTION,
          data:{ //实体中的数据名称
          addPostCollectionResponse:{},
          postCollections:[],
          deletePostCollectionsResponse:{},
          postCollectionName:'',
          postNumber:'0',
          postFieldList:[]
          }
          }
          }
  3. 所有代码结构,含一个api,一个action,两个component,一个reducers
  • api(查询 / 删除)
//查询
searchPostCollectionByActivityId(activityId, callback) {
const queryParam = `/tob/post/search?activeId=${activityId}`;
Config.get(queryParam, callback);
} //删除
deletePostCollections (activityId ,params, callback) {
let path = `/tob/post/deletePostCollection/${activityId}`;
Config.deleteWithNoResponse(path ,params, callback);
}
  • action(查询方法 / 更新选中实体数据方法 / 删除方法 / 清空实体数据方法 )
//查询表数据
export function initPostCollection(row){
return (dispatch, getState) => {
let activityId = row.activityId;
Api.searchPostCollectionByActivityId(activityId, params => {
dispatch(initPostCollectionSetter(activityId,params));
});
}
}
function initPostCollectionSetter(activityId,params){
return {
type:INIT_POST_COLLECTION,
activityId:activityId,
data:{postCollectionEntityList:params}
}
} //更新选中实体数据
export function formatPostCollectionList(row) {
return(dispatch, getState) => {
let postCollectionId = row.postCollectionId;
let state = getState().postCollectionState;
let postCollections = state.postCollections;
let postCollectionItem = {
postCollectionId:postCollectionId
};
if (postCollections) {
let index = -1;
for (let i = 0 ;i < postCollections.length ;i++) {
let postCollection = postCollections[i];
let id = postCollection.postCollectionId;
if (postCollectionId == id) {
index = i;
}
}
if (index > -1) {
postCollections.splice(index,1);
} else {
postCollections.push(postCollectionItem);
}
} else {
postCollections = [];
postCollections.push(postCollectionItem);
}
dispatch(formatPostCollectionListSetter(postCollections));
}
}
function formatPostCollectionListSetter(params){
return {
type:SET_POST_COLLECTIONS,
data:{postCollections:params}
}
} //删除方法
export const DELETE_POST_COLLECTIONS = 'DELETE_POST_COLLECTIONS';
export function deletePostCollections(){
return(dispatch, getState) => {
let state = getState().postCollectionState;
let activityId = state.activityId;
let postCollections = state.postCollections;
Api.deletePostCollections(activityId ,postCollections, params => {
dispatch(deletePostCollectionsSetter(params));
});
}
}
function deletePostCollectionsSetter(params){
alertPre("",params);
return {
type:DELETE_POST_COLLECTIONS,
data:{deletePostCollectionsResponse:params}
}
} //清空实体数据
export const CLEAR_POST_COLLECTION = 'CLEAR_POST_COLLECTION';
export function clearPostCollection(){
return {
type: CLEAR_POST_COLLECTION,
data:{
addPostCollectionResponse:{},
postCollections:[],
deletePostCollectionsResponse:{},
postCollectionName:'',
postNumber:'0',
postFieldList:[]
}
}
}
  • component(BtnDelData.js / TableData.js (checkbox))
//删除按钮组件
import React,{Component} from 'react';
import {render} from 'react-dom';
import ReactBootstrap , {ButtonToolbar,Button,Pagination} from 'react-bootstrap'; export default class BtnDelData extends Component {
constructor(props){
super(props);
} render(){
let dis = true;
let postCollections = this.props.postCollectionState.postCollections;
if (typeof(postCollections) == 'undefined' || postCollections.length == 0) {
dis = true;
} else {
dis = false;
} const buttonsInstanceDel = (
<ButtonToolbar className="mb10">
<Button bsStyle="danger" disabled={dis} onClick={this.props.deletePostCollections}>删除贴子集</Button>
</ButtonToolbar>
); return(
<div>
{buttonsInstanceDel}
</div>
)
}
} //表组件
import React, {Component} from 'react';
import {render} from 'react-dom';
import ReactBootstrap , {ButtonToolbar,Button,Pagination,Grid,Row,Col} from 'react-bootstrap';
import { Router, Route, IndexRoute, Link, IndexLink, browserHistory } from 'react-router';
const ACTIVE = { color: 'red' };
import {sessionSetItem,sessionGetItem} from 'storage'; import BtnAddData from './BtnAddData.js';
import BtnDelData from './BtnDelData.js'; //引用公共组件
import TableExit from 'public_component/table/TableExit.js';
import TableCloumnsExit from 'public_component/table/TableCloumnsExit.js'; //跳转路径
import {invitation_main_path,post_collection_main_path,activity_main_path,question_bank_main_path} from '/build/config.js'; export default class TableData extends Component {
constructor(props){
super(props);
} componentDidMount() {
const param = this.props.queryData;
console.log("param === " + param);
this.props.initPostCollection(param);
} componentDidUpdate () {
let deletePostCollectionsResponse = this.props.postCollectionState.deletePostCollectionsResponse;
if (typeof(deletePostCollectionsResponse) != 'undefined') {
let status = deletePostCollectionsResponse.status;
if (200 == status) {
this.props.clearPostCollection();
let param = {
activityId:this.props.postCollectionState.activityId
}
this.props.initPostCollection(param);
}
}
} //修改
activeFormatter(cell,row) {
return <Button bsStyle="primary" onClick={this.props.sendPostCollection.bind(null,row)}>推送</Button> } checkboxFormatter(cell,row) {
return <input bsStyle="primary" type="checkbox" onClick={this.props.formatPostCollectionList.bind(this,row)}></input>
} //修改
postCollectionFormatter(cell,row) {
return <Link to={{ pathname:post_collection_main_path, query: row}} activeStyle={ACTIVE}>修改</Link>
} questionBankFormatter(cell,row) {
return <Link to={{ pathname: question_bank_main_path, query: row}} activeStyle={ACTIVE} >查看题库</Link>
} render(){ let postCollectionEntityList = [
{
postCollectionName:'',
postCollectionId:'',
activityId:''
}
]; if (this.props.postCollectionState.postCollectionEntityList) {
postCollectionEntityList = this.props.postCollectionState.postCollectionEntityList;
console.log("postCollectionEntityList" + postCollectionEntityList);
} //let postCollectionEntityList = this.props.postCollectionState.postCollectionEntityList; //添加与删除
const gridInstance = (
<Grid className="mb5">
<Row className="show-grid">
<Col sm={1} mdPush={-7}><BtnAddData {...this.props} activityParam={this.props.queryData} /></Col>
<Col sm={1}><BtnDelData {...this.props} /></Col>
</Row>
</Grid>
); //acb 表数据
return(
<div>
{gridInstance}
<TableExit data={postCollectionEntityList} acb={this.props.initPostCollection}>
<TableCloumnsExit dataField="alter" dataFormat={this.checkboxFormatter.bind(this)}>选择</TableCloumnsExit>
<TableCloumnsExit dataField="activityTitle">活动名称</TableCloumnsExit>
<TableCloumnsExit dataField="postCollectionName">帖子集名称</TableCloumnsExit>
<TableCloumnsExit dataField="postCollectionId">帖子集编号</TableCloumnsExit>
<TableCloumnsExit dataField="active" dataFormat={this.postCollectionFormatter}>修改</TableCloumnsExit>
<TableCloumnsExit dataField="send" dataFormat={this.activeFormatter.bind(this)}>发送</TableCloumnsExit>
<TableCloumnsExit dataField="send" dataFormat={this.questionBankFormatter.bind(this)}>题库</TableCloumnsExit>
</TableExit>
<ButtonToolbar>
<Link className="btn btn-primary" to={{ pathname:activity_main_path}}>返回到活动界面</Link>
</ButtonToolbar>
</div>
);
}
}
  • reducers (state合并)

以上为删除功能的用法。

react.js CMS 删除功能的实现的更多相关文章

  1. React.js 小书 Lesson14 - 实战分析:评论功能(一)

    作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson14 转载请注明出处,保留原文链接和作者信息. 课程到这里大家已经掌握了 React.js 的 ...

  2. 前端迷思与React.js

    前端迷思与React.js 前端技术这几年蓬勃发展, 这是当时某几个项目需要做前端技术选型时, 相关资料整理, 部分评论引用自社区. 开始吧: 目前, Web 开发技术框架选型为两种的占 80% .这 ...

  3. React.js 小书 Lesson27 - 实战分析:评论功能(六)

    作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson27 转载请注明出处,保留原文链接和作者信息. (本文未审核) 删除评论 现在发布评论,评论不 ...

  4. React.js 小书 Lesson25 - 实战分析:评论功能(四)

    作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson25 转载请注明出处,保留原文链接和作者信息. (本文未审核) 目前为止,第二阶段知识已经基本 ...

  5. React.js 小书 Lesson16 - 实战分析:评论功能(三)

    作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson16 转载请注明出处,保留原文链接和作者信息. 接下来的代码比较顺理成章了.修改 Commen ...

  6. 基于touch.js 左滑删除功能

    左滑删除功能 完整代码如下: (touch.js) <!DOCTYPE html> <html> <head> <meta charset="UTF ...

  7. js jq 手机号实现(344) 附带删除功能 jq 实现银行卡没四个数加一个空格 附带删除功能

    js 手机号实现(344)  下面有将正则验证去掉“-” 或“空格”  下一篇博客有单独的删除功能方法 <!DOCTYPE html> <head> <meta char ...

  8. React.js 小书 Lesson26 - 实战分析:评论功能(五)

    作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson26 转载请注明出处,保留原文链接和作者信息. (本文未审核) 持久化评论 同样地,可以通过类 ...

  9. React.js 小书 Lesson15 - 实战分析:评论功能(二)

    作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson15 转载请注明出处,保留原文链接和作者信息. 上一节我们构建了基本的代码框架,现在开始完善其 ...

随机推荐

  1. java编程思想读书笔记2

    六:访问权限控制 1.java中的4种访问制权限: (1).public:最大访问控制权限,对所有的类都可见. (2).protect:同一包可见,不在同一个包的所有子类也可见. (3).defaul ...

  2. 最短路径问题的Dijkstra和SPFA算法总结

    Dijkstra算法: 解决带非负权重图的单元最短路径问题.时间复杂度为O(V*V+E) 算法精髓:维持一组节点集合S,从源节点到该集合中的点的最短路径已被找到,算法重复从剩余的节点集V-S中选择最短 ...

  3. POJ 1696 Space Ant 【极角排序】

    题意:平面上有n个点,一只蚂蚁从最左下角的点出发,只能往逆时针方向走,走过的路线不能交叉,问最多能经过多少个点. 思路:每次都尽量往最外边走,每选取一个点后对剩余的点进行极角排序.(n个点必定能走完, ...

  4. HMAC算法AS3版

    http://www.cnblogs.com/appleseed/archive/2008/09/17/1292232.html

  5. [No000039]操作系统Operating Systems用户级线程User Threads

    多进程是操作系统的基本图像 是否可以资源不动而切换指令序列? 进程 = 资源 + 指令执行序列 线程: 保留了并发的优点,避免了进程切换代价 实质就是映射表不变而PC 指针变 多个执行序列+ 一个地址 ...

  6. linux基本工具使用(二)

    1 查找某个目录下面一个所有的可执行文件,并且删除(对删除一个工程的可执行文件格外有用) find . -maxdepth 1 -file f -perm -111 | xargs rm

  7. NET WebApi OWIN 实现 OAuth 2.0

    NET WebApi OWIN 实现 OAuth 2.0 OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列表),而无需将用户名和 ...

  8. silverlight 4 tools for vs2010无法在vs2010 SP1上安装的解决办法

    环境:英文版vs2010 sp1 + vs2013 RC 90天体验版 原来可以正常做silverilght 4 项目开发,今天因为vs2013 RC过了90天体验期,卸载时顺带把Silverlihg ...

  9. Mybatis.Net 整合 ODP.NET Managed

    初步接触MyBatis.Net的朋友,请先移步 MyBatis.Net 学习手记 1. 项目中先添加Oracle.ManagedDataAccess.dll程序集引用 2. MyBatis.Net 中 ...

  10. 纯html的table打印注意事项

    1. 在firefox下,每页均会打印重复thead(表头),tfoot(表尾)的内容:IE8下无效(其它IE版本未测试) 2. 分页的处理 @media print {     .page-brea ...