React学习笔记—简易信息管理,实现CUD

韩玄
• 阅读 5776

需求

利用React实现一个简易的信息管理系统。
React学习笔记—简易信息管理,实现CUD

写的不太好,欢迎熟悉React的大神来找茬。真心感激!

分析

编写React就是不断构建组件的过程,首先要根据需求进行UI的划分:

-StudentBox
  -StudentList
    -Student
  -StudentForm

编码

服务端

没有用到服务器,采用了数据模拟的方式

var id = 41060122; //添加信息时自增长ID

var data = [
    {
        id: 41060120,
        name: 'Mary',
        age: 20
    },
    {
        id: 41060121,
        name: 'Jacky',
        age: 18
    },
    {
        id: 41060122,
        name: 'Helen',
        age: 21
    }
];

页面

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>React</title>
    <link rel="stylesheet" href="css/bootstrap.css"/>
    <link rel="stylesheet" href="css/style.css"/>
</head>
<body>
<script src="js/lib/react.js"></script>
<script src="js/lib/JSXTransformer.js"></script>
<script src="js/lib/underscore.js"></script>
<script src="js/table.js" type="text/jsx;harmony=true"></script>
</body>
</html>

组件

StudentBox

var StudentBox = React.createClass({
    getInitialState: function () {
        return {data: data};
    },
    //删除
    handleDelete: function (index) {
        this.state.data.splice(index, 1);
        this.forceUpdate();
    },
    //更新
    handleUpdate: function (student) {
        this.state.data.forEach(function (item) {
            if (item.id === student.id) {
                _.extend(item, student);
            }
        });
        this.forceUpdate();
    },
    //新增
    handleSave: function (student) {
        this.state.data.push(_.extend(student, {id: ++id}));
        this.forceUpdate();
    },
    render: function () {
        return (
            <div className="container">
                <div className="page-header">
                    <h1>Student Messages</h1>
                </div>
                <StudentList data={this.state.data} delete={this.handleDelete} update={this.handleUpdate}/>
                <StudentForm save={this.handleSave}/>
            </div>
        )
    }
});

StudentList

var StudentList = React.createClass({
    render: function () {
        var handleDelete = this.props.delete;
        var handleUpdate = this.props.update;
        return (
            <table className="table table-striped table-hover">
                <thead>
                <tr>
                    <th>index</th>
                    <th>number</th>
                    <th>name</th>
                    <th>age</th>
                    <th>operation</th>
                </tr>
                </thead>
                <tbody id="tbody">
                {this.props.data.map(function (student, index) {
                    return <Student index={index} data={student} delete={handleDelete} update={handleUpdate}/>
                })}
                </tbody>
            </table>
        )
    }
});

Student

var Student = React.createClass({
    getInitialState: function () {
        return {isEdit: false};
    },
    handleEdit: function () {
        this.setState({isEdit: !this.state.isEdit});
    },
    handleDelete: function (index) {
        this.props.delete(index);
    },
    handleUpdate: function (id) {
        var name = React.findDOMNode(this.refs.name).value.trim();
        var age = React.findDOMNode(this.refs.age).value.trim();

        if (!name || !age) {
            return;
        }

        this.props.update({
            id: id,
            name: name,
            age: age
        });
        this.handleEdit();
    },
    render: function () {
        var index = this.props.index;
        var student = this.props.data;

        var operations = this.state.isEdit ?
            <div>
                <button className="btn btn-primary btn-xs" onClick={this.handleUpdate.bind(this,student.id)}>save
                </button>
                <button className="btn btn-info btn-xs" onClick={this.handleEdit}>cancel
                </button>
            </div> :
            <div>
                <button className="btn btn-default btn-xs" onClick={this.handleEdit.bind(this,index)}>edit</button>
                <button className="btn btn-danger btn-xs" onClick={this.handleDelete.bind(this,index)}>delete
                </button>
            </div>;


        var name = this.state.isEdit ?
            <input type="text" className="form-control input-sm" defaultValue={student.name}
                   ref="name"/> : student.name;

        var age = this.state.isEdit ?
            <input type="text" className="form-control input-sm" defaultValue={student.age} ref="age"/> : student.age;

        return (
            <tr>
                <td>{index}</td>
                <td>{student.id}</td>
                <td>{name}</td>
                <td>{age}</td>
                <td>{operations}</td>
            </tr>
        )
    }
});

StudentForm

var StudentForm = React.createClass({
    handleSubmit: function (e) {
        e.preventDefault();

        var name = React.findDOMNode(this.refs.name).value.trim();
        var age = React.findDOMNode(this.refs.age).value.trim();

        if (!name || !age) {
            return;
        }

        this.props.save({
            name: name,
            age: age
        });
    },
    render: function () {
        return (
            <form onSubmit={this.handleSubmit}>
                <div className="row">
                    <div className="col-xs-5">
                        <input type="text" ref="name" className="form-control input-sm" placeholder="student name"/>
                    </div>
                    <div className="col-xs-5">
                        <input type="text" ref="age" className="form-control input-sm" placeholder="student age"/>
                    </div>
                    <div className="col-xs-2">
                        <button type="submit" className="btn btn-warning btn-sm">Add student</button>
                    </div>
                </div>
            </form>

        )
    }
});

渲染

React.render(
    <StudentBox />,
    document.body
);
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
梦
4年前
微信小程序new Date()转换时间异常问题
微信小程序苹果手机页面上显示时间异常,安卓机正常问题image(https://imghelloworld.osscnbeijing.aliyuncs.com/imgs/b691e1230e2f15efbd81fe11ef734d4f.png)错误代码vardate'2021030617:00:00'vardateT
Stella981 Stella981
3年前
SpringBoot整合Redis乱码原因及解决方案
问题描述:springboot使用springdataredis存储数据时乱码rediskey/value出现\\xAC\\xED\\x00\\x05t\\x00\\x05问题分析:查看RedisTemplate类!(https://oscimg.oschina.net/oscnet/0a85565fa
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Easter79 Easter79
3年前
SpringBoot整合Redis乱码原因及解决方案
问题描述:springboot使用springdataredis存储数据时乱码rediskey/value出现\\xAC\\xED\\x00\\x05t\\x00\\x05问题分析:查看RedisTemplate类!(https://oscimg.oschina.net/oscnet/0a85565fa
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
达里尔 达里尔
1年前
给数组添加新数据,判断数据是否重复
多选要进行数组拼接,希望判断往原数组里添的新数据是否重复,封装个简易方法languageconstdataArrayname:'aaa',id:1,name:'bbb',id:2;constnewDataname:'ccc',id:2;//要添加的新数
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
美凌格栋栋酱 美凌格栋栋酱
5个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(