列表頁(yè)篩選組件設(shè)計(jì)

UI 稿

功能描述

  • 默認(rèn)選中全部,即獲取全部列表數(shù)據(jù)。當(dāng)點(diǎn)擊“通識(shí)類”或“實(shí)訓(xùn)類”按鈕時(shí),切換選中選項(xiàng),改變路由,并重新獲取列表數(shù)據(jù)。

API

  • 全部、通識(shí)類、實(shí)訓(xùn)類分別用id 表示為 -1,1,2
  • 默認(rèn)不帶查詢參數(shù)時(shí)會(huì)獲取全部數(shù)據(jù)列表
  • 當(dāng)選擇實(shí)訓(xùn)或通識(shí)時(shí),傳入對(duì)應(yīng)的id, 如 /api/courseware/list?propertyId=id

Component: Filter

Props

  • options: [{id: -1, title:"全部”},{id: 1, title: "通識(shí)類“},{id: 2, title: "實(shí)訓(xùn)類”}], 用于渲染篩選項(xiàng)文字和給每個(gè)選項(xiàng)綁定id
  • currentId: 當(dāng)屬性不存在時(shí),默認(rèn)為“-1"
  • handleChange: 當(dāng)篩選按鈕被點(diǎn)擊時(shí)調(diào)用,傳遞 id 作為參數(shù)

代碼

import React from 'react'
import cx from 'classnames'
import styles from './Filter.scss'

const Filter = ({ options, currentId, handleChange }) => {
  const optionsList = options.map(item => (
    <button
      key={item.id}
      className={cx(styles.item, {
        [styles.active]: item.id === currentId,
      })}
      onClick={() => {
        handleChange(item.id)
      }}
    >
      {item.name}
    </button>
  ))

  return (
    <div className={styles.root}>
      <div className={styles.title}>性質(zhì)</div>
      <div className={styles.options}>
        {optionsList}
      </div>
    </div>
  )
}

export default Filter

頁(yè)面組件

Props

  • history: 用于改變路由

Action

  • fetchCoursewareList
    • 參數(shù):選項(xiàng)對(duì)應(yīng)的id, 僅當(dāng)不為-1時(shí)
    • 返回值:課件列表相關(guān)數(shù)據(jù), 用于渲染頁(yè)面

componentWillReceiveProps

屬性改變時(shí)會(huì)自動(dòng)觸發(fā)該函數(shù),需比較當(dāng)路由不同時(shí),調(diào)用fetchCoursewareList Action。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,568評(píng)論 19 139
  • ¥開啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個(gè)線程,因...
    小菜c閱讀 7,334評(píng)論 0 17
  • 《裕語(yǔ)言》速成開發(fā)手冊(cè)3.0 官方用戶交流:iApp開發(fā)交流(1) 239547050iApp開發(fā)交流(2) 10...
    葉染柒丶閱讀 28,753評(píng)論 5 20
  • 我是愛你的,我所知的最重要的事情,是我是愛你的。我愛你這件事,與許許多多的客觀的事實(shí)無關(guān),也忽視那些我所不知的。我...
    Rsnzj閱讀 156評(píng)論 0 0
  • 陳列設(shè)計(jì)書單 1.光線色彩 色彩與光線 實(shí)用燈光與顏色 2.生活中的符號(hào) 符號(hào)學(xué) 3.顏色 素材庫(kù) 世界門店櫥窗設(shè)...
    Gemini77閱讀 206評(píng)論 0 0

友情鏈接更多精彩內(nèi)容