React 학습 노트 - 간단 한 정보 관리, CUD 실현
React 를 이용 하여 간단 하고 쉬 운 정보 관리 시스템 을 실현 하 다.
잘 쓰 지 못 했 습 니 다. 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
    }
];
  페이지
    
    React 
    
    
 
 
 
   구성 요소
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 (
            
                
                    Student Messages
                
                
                
              
        )
    }
});
  StudentList
var StudentList = React.createClass({
    render: function () {
        var handleDelete = this.props.delete;
        var handleUpdate = this.props.update;
        return (
            
                
                
                    index 
                    number 
                    name 
                    age 
                    operation 
                 
                
                
                {this.props.data.map(function (student, index) {
                    return 
                })}
                 
            
        )
    }
});
  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 ?
            
                
                
             :
            
                
                
            ;
        var name = this.state.isEdit ?
             : student.name;
        var age = this.state.isEdit ?
             : student.age;
        return (
            
                {index} 
                {student.id} 
                {name} 
                {age} 
                {operations} 
             
        )
    }
});
  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 (
            
        )
    }
});
  과장 하 다
React.render(
     ,
    document.body
);
                이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Thymeleaf 의 일반 양식 제출 과 AJAX 제출텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.