前端相关 - redux项目搭建

博客代码内容根据技术胖老师系列教程整理,如有侵权,请联系博主删除

src目录结构
src
 store
  index.js
  reducer.js
 index.js
 TodoList.js

src中 index,js 内容

import React from 'react'
import ReactDOM from 'react-dom'
import TodoList from './TodoList'
import {Provider} from 'react-redux'
import store from './store'
const App = (
    <Provider store={store}>
        <TodoList/>
    </Provider>
)
ReactDOM.render(
    App,
    document.getElementById("root")
);

src中 TodoList,js 内容

import React, {Component} from "react"
import {connect} from 'react-redux'
class TodoList extends Component {
    render() {
        return (
            <div>
                <input
                    value={ this.props.inputvalue}
                    onChange={this.props.inputchange}
                />
                <button>提交</button>
                <ul>
                    <li>{ this.props.inputvalue}</li>
                </ul>
            </div>
        );
    }
}
const stateToProps = (state)=>{
    return{
        inputvalue: state.inputvalue
    }
};

const dispatchToProps = (dispatch)=>{
    return {
        inputchange(e){
            console.log(e)
            let action = {
                type: "chang_input",
                value: e.target.value
            }
            dispatch(action)
        }
    }
}
export default connect(stateToProps,dispatchToProps)(TodoList);

store中 index.js 内容

import React from 'react'
import {createStore} from 'redux'
import reducer from './reducer'

const store = createStore(reducer);
export default store

store中 reducer.js 内容

const defaultState = {
    inputvalue: '',
    list: []
};
export default (state = defaultState, action) => {
    if (action.type == 'chang_input'){
        let newstate = JSON.parse(JSON.stringify(state))
        newstate.inputvalue = action.value;
        return newstate
    }
    return state
}

src中 TodoList,js 优化
直接使用箭头函数,不用定义class

import React, {Component} from "react"
import {connect} from 'react-redux'

const TodoList = (props) => {
    let {inputvalue, inputchange, clickbutton, list} = props
    return (
        <div>
            <input
                value={inputvalue}
                onChange={inputchange}
            />
            <button onClick={clickbutton}>提交</button>
            <ul>
                {list.map((items, index) => {
                    return (<li key={index}>{items}</li>)
                })}
            </ul>
        </div>
    );
}

const stateToProps = (state) => {
    return {
        inputvalue: state.inputvalue,
        list: state.list
    }
}

const dispatchToProps = (dispatch) => {
    return {
        inputchange(e) {
            console.log(e)
            let action = {
                type: "chang_input",
                value: e.target.value
            }
            dispatch(action)
        },
        clickbutton() {
            console.log("111111111111")
            let action = {
                type: "add_item"
            }
            dispatch(action)
        }
    }
}

export default connect(stateToProps, dispatchToProps)(TodoList);

src中 TodoList,js 优化
将UI部分提出

  • TodoList.js
import React, {Component} from "react"
import {connect} from 'react-redux'

const TodoList = (props) => {
    let {inputvalue, inputchange, clickbutton, list} = props
    return (
        <div>
            <input
                value={inputvalue}
                onChange={inputchange}
            />
            <button onClick={clickbutton}>提交</button>
            <ul>
                {list.map((items, index) => {
                    return (<li key={index}>{items}</li>)
                })}
            </ul>
        </div>
    );
}

const stateToProps = (state) => {
    return {
        inputvalue: state.inputvalue,
        list: state.list
    }
}

const dispatchToProps = (dispatch) => {
    return {
        inputchange(e) {
            console.log(e)
            let action = {
                type: "chang_input",
                value: e.target.value
            }
            dispatch(action)
        },
        clickbutton() {
            console.log("111111111111")
            let action = {
                type: "add_item"
            }
            dispatch(action)
        }
    }
}

export default connect(stateToProps, dispatchToProps)(TodoList);
  • TodoListUI.js
import React, {Component} from "react"
import {connect} from 'react-redux'
import {Input, Button, List} from "antd"
import "antd/dist/antd.css"
import store from "./store"
class TodoListUi extends Component {
    render() {
        return (
            <div style={{margin:'20px'}}>
                <div>
                    <Input
                        placeholder={"write somting "} style={{width:"200px"}}
                        onChange={this.changvalue}
                    />
                    <Button type="primary" onClick={this.clickbutton}>點擊</Button>
                </div>
                <div style={{width:'200px',height:"100px"}}>
                    <List
                        bordered
                        dataSource={this.state.datalist}
                        renderItem={item=>(<List.Item>{item}</List.Item>)}
                    />
                </div>
            </div>
        );
    }

    changvalue(e){
        const action={
            type:"change_input",
            value: e.target.value
        }
        store.dispatch(action)
    }
    clickbutton() {
        console.log("111111111111")
        let action = {
            type: "add_item"
        }
        store.dispatch(action)
    }

    storeChange(){
        this.setState(store.getState())
    }
}
export default TodoListUi;

action优化

  • actionTypes.js
export const GET_USER_DATA = "getUserData"
export const CHANGE_INPUT = "change_input"
export const ADD_ITEM = "add_item"
  • actionCreater.js
import {GET_USER_DATA, CHANGE_INPUT, ADD_ITEM} from "./actionTypes"

export const getUserData = (value) => ({
    type: GET_USER_DATA,
    value
});

export const changvalue = (value) => ({
    type: CHANGE_INPUT,
    value
});

export const changvalue2 = (value) => ({
    type: ADD_ITEM,
    value
});
  • reducer.js
import {GET_USER_DATA, CHANGE_INPUT, ADD_ITEM} from "./actionTypes"
const defaultState = {
    inputvalue: '寫點神魔',
    datalist: ["開UI安監局",
        "開竈火"
    ]
};
export default (state = defaultState, action) => {
    if (action.type == CHANGE_INPUT) {
        let newstate = JSON.parse(JSON.stringify(state))
        newstate.inputvalue = action.value
        return newstate
    }
    if (GET_USER_DATA){
        console.log("sssssssssssss")
        let newstate = JSON.parse(JSON.stringify(state))
        console.log(JSON.stringify(action.value))
        newstate.datalist = action.result;
        return newstate
    }
    return state
}
  • TodoList.js
import React, {Component} from "react"
import "antd/dist/antd.css"
import store from "./store"
import TodoListUi from "./TodoListUi"
import axios from "axios"
import {GET_USER_DATA, CHANGE_INPUT, ADD_ITEM} from "./store/actionTypes"
import {getUserData,changvalue} from "./store/actionCreater"

class TodoList extends Component {
    constructor(propos) {
        super(propos)
        this.state = store.getState()
        this.changvalue = this.changvalue.bind(this)
        this.storeChange = this.storeChange.bind(this)
        this.clickbutton = this.clickbutton.bind(this)
        store.subscribe(this.storeChange)
    }

    render() {
        return (
            <TodoListUi
                datalist={this.state.datalist}
                changevalue={this.changvalue}
                clickbutton={this.clickbutton}
            />
        );
    }

    changvalue(e) {
        const action = changvalue(e.target.value)
        store.dispatch(action)
    }

    clickbutton() {
        console.log("111111111111")
        let action = {
            type: ADD_ITEM
        }
        store.dispatch(action)
    }

    componentDidMount() {
        axios.get("http://127.0.0.1:3001")
            .then((res) => {
                console.log(res)
                const datas = res.data
                const action = getUserData(datas)
                console.log(action)
                store.dispatch(action)
            }).catch( (error) => {
            console.log(error);
        });
    }

    storeChange() {
        this.setState(store.getState())
    }
}

export default TodoList;
  • TodoListUi.js
import React, {Component} from "react"
import {connect} from 'react-redux'
import {Input, Button, List} from "antd"
import "antd/dist/antd.css"
class TodoListUi extends Component {
    render() {
        return (
            <div style={{margin:'20px'}}>
                <div>
                    <Input style={{width:"200px"}}
                        onChange={this.props.changvalue}
                    />
                    <Button type="primary" onClick={this.props.clickbutton}>點擊</Button>
                </div>
                <div style={{width:'200px',height:"100px"}}>
                    <List
                        bordered
                        dataSource={this.props.datalist}
                        renderItem={item=>(<List.Item>{item}</List.Item>)}
                    />
                </div>
            </div>
        );
    }
}
export default TodoListUi;
  • index.js
import React from 'react'
import ReactDOM from 'react-dom'
import TodoList from './TodoList'
const App = (
    <TodoList/>
)
ReactDOM.render(
    App,
    document.getElementById("root")
);

结构示例
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip
综合小区管理系统管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、车位管理、车位分配管理、出入管理、字典管理、房屋管理、物业费缴纳管理、公告管理、物业人员投诉管理、我的私信管理、物业人员管理、用户管理、管理员管理。用户的功能包括管理部门以及部门岗位信息,管理招聘信息,培训信息,薪资信息等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 综合小区管理系统管理系统可以提高综合小区管理系统信息管理问题的解决效率,优化综合小区管理系统信息处理流程,保证综合小区管理系统信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理综合小区管理系统信息,包括出入管理,报修管理,报修管理,物业费缴纳等,可以管理操作员。 出入管理界面,管理员在出入管理界面中可以对界面中显示,可以对招聘信息的招聘状态进行查看,可以添加新的招聘信息等。报修管理界面,管理员在报修管理界面中查看奖罚种类信息,奖罚描述信息,新增奖惩信息等。车位管理界面,管理员在车位管理界面中新增。公告管理界面,管理员在公告管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值