react 中的redux实现数据的添加删除

1、新建store
新建component
在store新建index.js代码如下:

import {createStore} from "redux";



const store = createStore();


export default store;

2、在store里创建文件夹reducer,在reducer里新建文件todo.js文件代码如下:

const defaultState = {
    inputVal: "",
    list: []

}
export default (state = defaultState, action) => {
   
            return state;
    }


3、在store里的index.js中引入todo 合并
代码如下:

import {createStore,combineReducers} from "redux";
import todo from "./reducers/todo"

let reducer = combineReducers({
    todo
})
 
const store = createStore(reducer);


export default store;

4、在component中创建input组件和list组件

import React, { Component, Fragment } from 'react'

export default class Input extends Component {
    render() {
        return (
            <Fragment>
              <input type="text" />
              <button>点击</button>
           </Fragment>
import React, { Component, Fragment } from 'react'

export default class List extends Component {
    render() {
        return (
            <Fragment>
            <ul>
            <li>111</li>
            </ul>
           </Fragment>

5、在App.js中引入input 和list

import React, { Component } from 'react'
import Input from './component/input'
import List from './component/list'

export default class App extends Component {
  
    
    render() {
        return (
            <div>
                <Input/>
                <List/>
            </div>
        )
    }
}

6、在input.js中引入store并添加事件订阅

import React, { Component, Fragment } from 'react'
import store from "../store"
export default class Input extends Component {
    constructor() {
        super();
        this.state = store.getState();
        store.subscribe(this.handleUpdate.bind(this))
    }

    render() {
        let { inputVal } = this.state.todo;
        return (
           <Fragment>
              <input type="text" />
              <button>点击</button>
           </Fragment>
        )
    }
  
    handleChange(e) {
        let val = e.target.value;
       
    }
    handleUpdate() {
        this.setState(store.getState());
    }

}

7、在src中新建文件夹action在action中新建文件 actionCreator.js

export const changeAction = (val)=>({
    type:"TODO_CHANGE",
    value:val
})

8、在input,js中引入

import { changeAction} from '../action/actionCreator'

通过store.dispatch发送Action
在这里插入图片描述

  store.dispatch(changeAction(val));

9、reducer/todo.js(拷贝加渲染数据)

const defaultState = {
    inputVal: "",
    list: []

}
export default (state = defaultState, action) => {
    switch (action.type) {
        case "TODO_CHANGE":
            let changeState = Object.assign({}, state);//拷贝
            changeState.inputVal = action.value;//渲染数据
            return changeState;
        default:
            return state;
    }

}

10、在input.js中设置点击添加数据

  <Fragment>
               <input type="text" value={inputVal} onChange={this.handleChange.bind(this)} />
            
                <button onClick={this.handleAdd.bind(this)}>添加</button>
            </Fragment>

11、在actionCreator.js中继续写

export const todoAdd = {
    type:"TODO_ADD"
}

再回到input.js中引入

import { changeAction,todoAdd} from '../action/actionCreator'

在这里插入图片描述

handleAdd(){
	store.dispatch(todoAdd);
}

12、回到todo.js中 (目的可以进行添加但是不显示在页面上),下一步做遍历让数据渲染到页面上在这里插入图片描述

  case "TODO_ADD":
            let addState = Object.assign({}, state);
            addState.list.push(addState.inputVal);
            addState.inputVal = "";

13、回到list.js中引入

import store from "../store"

写上事件订阅,并添加删除按钮功能

export default class List extends Component {
    constructor() {
        super();
        this.state = store.getState();
        store.subscribe(this.handleUpdate.bind(this))
    }

完整代码:

import React, { Component } from 'react'
import store from "../store"
import { todoDel } from "../action/actionCreator"
export default class List extends Component {
    constructor() {
        super();
        this.state = store.getState();
        store.subscribe(this.handleUpdate.bind(this))
    }
   render() {
        let { list } = this.state.todo
        return (
            <ul>
                {
                    list.map((item, index) => (
                        <li key={index}>{item}
                            <button onClick={this.handleDel.bind(this,index)}>删除</button>
                        </li>
                    ))
                }
            </ul>
        )
    }
    handleDel(index) {
        store.dispatch(todoDel(index))
    }
    handleUpdate() {
        this.setState(store.getState());
    }
}

14、转到actionCreator.js中

export const todoDel = (val)=>({
    type:"TODO_DEL",
    value:val
})

15、在list.js中引入

import { todoDel } from "../action/actionCreator"

在这里插入图片描述

handleDel(index) {
        store.dispatch(todoDel(index))
    }

再回到todo.js中 做拷贝 做删除

  case "TODO_DEL":
            let delState = Object.assign({}, state);
            delState.list.splice(action.value,1);
         
            return delState;

16、最终效果(实现了添加删除)
在这里插入图片描述

后续的一些问题
没有结构赋值
在这里插入图片描述
没匹配对应的在这里插入图片描述
没return
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值