iT邦幫忙

1

React 學習筆記_29(在React中使用Redux - 5)

  • 分享至 

  • xImage
  •  

簡介

上一篇中我們已經將大部分的內容與功能都建立完成,最後要建立的便是給使用者選擇要看到那些Todo的選項按鈕,顯示篩選分別為 :

  • 全部Todo
  • 已經完成的Todo (completed : true)
  • 尚未完成的Todo (completed : false)

篩選Todo的流程

  1. 當Link.js中的超連結被點擊,會進入由FilterLink透過connect傳遞的callback function(mapDispatchToProps())。
  2. mapDispatchToProps()會將篩選的action dispatch到Reducer進行處理,處理完後return一個新的State。
  3. 當return新的state後,由於state的改變便會呼叫到整個專案的mapStateToProps,雖然會呼叫整個專案的mapStateToProps,但只有visibleTodoList的mapStateToProps符合。
  4. visibleTodoList中的mapStateToProps將Todos篩選後return結果給TodoList進行UI選染。

流程圖 :
https://ithelp.ithome.com.tw/upload/images/20200516/20124767ALWnatJ7mr.png

FilterLink.js

import { connect } from "react-redux";
import { setVisibilityFilter } from "../Store/Action/Action";
import Link from "../Presentational Component/Link";

//當State更新後自動調用
const mapStateToProps = (state, ownProps) => {
    //ownProps : 傳遞給FilterLink組件的元素,包含props與childran(標籤中的元素)
    return {
      active: ownProps.filter === state.visibilityFilter
    }
}

//將onClick傳遞給Presentational Components作為callback
const mapDispatchToProps = (dispatch, ownProps) => {
    return {
      onClick: () => {
          console.log(ownProps.filter)
        dispatch(setVisibilityFilter(ownProps.filter))
      }
    }
}

//將判斷filter的結果與callback藉由connect傳遞給Link
const FilterLink = connect(
    mapStateToProps,
    mapDispatchToProps
)(Link)
  
export default FilterLink

Link.js

import React from "react";

const Link = (props) => {
    if(props.active){
        return(
            <span>{props.children}</span>
        )
    }

    return(
        <a 
            href="#"
            onClick={e=>{
                e.preventDefault();
                props.onClick()
            }}
        >
            {props.children}
        </a>
    )
};

export default Link;

Footer.js

import React from "react";
import FilterLink  from "../Container Component/FilterLink";

const Footer = (props) => (
    <p>
      Show:
      {" "}
      <FilterLink filter="SHOW_ALL">
        {/* childran */}
        All
      </FilterLink>
      {", "}
      <FilterLink filter="SHOW_ACTIVE">
        Active
      </FilterLink>
      {", "}
      <FilterLink filter="SHOW_COMPLETED">
        Completed
      </FilterLink>
    </p>
)
  
export default Footer

結論

節由這個練習可以更加瞭解Redux處理數據的方法,將數據交給Redux進行處理後再將處理完的數據傳遞給Presentational Component進行UI渲染,不需要再考慮組件之間state的傳遞、提升state的問題,在更大型的專案中更能夠體現使用Redux的好處。

參考資料 :
從Redux 的作者學習它


圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言