React中使用Ant Table組件

一、Ant Design of React

  http://ant.design/docs/react/introduce

二、建立webpack工程

    webpack+react demo下載

    項目的啟動,參考

三、簡單配置

  1.工程下載下來之后,在src目錄下新建目錄“table”,新建app.js,內容如下。

import React from 'react';
import ReactDOM from 'react-dom';
import ExampleTable from './ExampleTable';
import 'antd/dist/antd.css';
ReactDOM.render
(<ExampleTable />,
   document.body
);

  注:記住引入antd.css, 否則Table組件無法正常顯示。

  2.新建ExampleTable.js, 內容如下。

import { Table } from 'antd';
import React from 'react';class ExampleTable extends React.Component {constructor(props) {super(props);this.showCurRowMessage = this.showCurRowMessage.bind(this);}componentDidMount() {}//展示當前行信息
  showCurRowMessage(record){alert("key:"+record.key + " name:"+record.name + " age:" + record.age + " address:" + record.address + " description:" + record.description);}render() {let self = this;const columns = [{ title: '姓名', dataIndex: 'name', key: 'name' },{ title: '年齡', dataIndex: 'age', key: 'age', render: (text, record, index) => (Math.floor(record.age/10))*10+"多歲"},{ title: '住址', dataIndex: 'address', key: 'address' },{ title: '描述', dataIndex: 'description', key: 'description' },{ title: '操作', dataIndex: '', key: 'operation', render: function(text, record, index) {alert(text.operation + " " + record.operation)return <a href="#" name="delete" onClick={function() { self.showCurRowMessage(record)} } >信息</a>; } },//精簡寫法//{ title: '操作', dataIndex: '', key: 'operation', render: (text, record, index) => <a href="#" name="delete" onClick={() => self.showCurRowMessage(record)}>信息</a> },
    ];const data = [{ key: 1, name: 'hyw', age: 32, address: '西湖區湖底公園1號', description: '我是hyw,今年32歲,住在西湖區湖底公園1號。', children:[{ key: 1.1, name: 'fas', age: 32, address: '西湖區湖底公園1號', description: '我是fas,今年32歲,住在西湖區湖底公園1號。' },{ key: 1.2, name: 'wyz', age: 42, address: '西湖區湖底公園2號', description: '我是wyz,今年42歲,住在西湖區湖底公園2號。' },{ key: 1.3, name: 'ldz', age: 32, address: '西湖區湖底公園3號', description: '我是ldz,今年32歲,住在西湖區湖底公園3號。' },]},{ key: 2, name: 'lkx', age: 32, address: '西湖區湖底公園1號', description: '我是lkx,今年32歲,住在西湖區湖底公園1號。' },{ key: 3, name: 'mnk', age: 42, address: '西湖區湖底公園2號', description: '我是mnk,今年42歲,住在西湖區湖底公園2號。' },{ key: 4, name: 'xyt', age: 32, address: '西湖區湖底公園3號', description: '我是xyt,今年32歲,住在西湖區湖底公園3號。' },];const rowSelection = {onChange(selectedRowKeys, selectedRows) {console.log(`selectedRowKeys: ${selectedRowKeys}`, 'selectedRows: ', selectedRows);},onSelect(record, selected, selectedRows) {console.log(record, selected, selectedRows);},onSelectAll(selected, selectedRows, changeRows) {console.log(selected, selectedRows, changeRows);},};return (<div><Table columns={columns} rowSelection={rowSelection}dataSource={data}className="table"/></div>
    );}
}module.exports = ExampleTable;

  3.修改入口地址

  打開webpack.config.js,修改entry配置。

  entry: ['webpack/hot/only-dev-server',"./src/table/app.js"],

四、Table組件屬性

1.Table

參數說明類型默認值
rowSelection列表項是否可選擇,配置項Objectnull
pagination分頁器,配置項參考?pagination,設為 false 時不顯示分頁Object?
size正常或迷你類型,default?or?smallStringdefault
dataSource數據數組Array?
columns表格列的配置描述,具體項見下表Array-
rowKey表格行 key 的取值,可以是字符串或一個函數String or Function(record, index):string'key'
rowClassName表格行的類名Function(record, index):string-
expandedRowRender額外的展開行Function-
defaultExpandedRowKeys默認展開的行Array-
expandedRowKeys展開的行,控制屬性Array-
onChange分頁、排序、篩選變化時觸發Function(pagination, filters, sorter)?
loading頁面是否加載中Booleanfalse
locale默認文案設置,目前包括排序、過濾、空數據文案ObjectfilterConfirm: '確定'?
filterReset: '重置'?
emptyText: '暫無數據'?
默認值
indentSize展示樹形數據時,每層縮進的寬度,以 px 為單位Number15
onRowClick處理行點擊事件Function(record, index)-
useFixedHeader是否固定表頭Booleanfalse
bordered是否展示外邊框和列邊框Booleanfalse
showHeader是否顯示表頭Booleantrue
footer表格底部自定義渲染函數Function(currentPageData)?
scroll橫向或縱向支持滾動,也可用于指定滾動區域的寬高度:{{ x: true, y: 300 }}Object-

2.Column

  列描述數據對象,是 columns 中的一項。

參數說明類型默認值
title列頭顯示文字String or React.Element-
keyReact 需要的 key,建議設置String-
dataIndex列數據在數據項中對應的 key,支持?a.b.c?的嵌套寫法String-
render生成復雜數據的渲染函數,參數分別為當前行的值,當前行數據,行索引,@return里面可以設置表格行/列合并Function(text, record, index) {}-
filters表頭的篩選菜單項Array-
onFilter本地模式下,確定篩選的運行函數Function-
filterMultiple是否多選Booleantrue
filterDropdown可以自定義篩選菜單,此函數只負責渲染圖層,需要自行編寫各種交互React.Element-
sorter排序函數,本地排序使用一個函數,需要服務端排序可設為 trueFunction or Boolean-
colSpan表頭列合并,設置為 0 時,不渲染Number?
width列寬度String or Number-
className列的 classNameString-
fixed列是否固定,可選?true(等效于 left)?'left'?'right'Boolean or Stringfalse
filteredValue篩選的受控屬性,外界可用此控制列的篩選狀態,值為已篩選的 value 數組Array-
sortOrder排序的受控屬性,外界可用此控制列的排序,可設置為?'ascend''descend'?falseBoolean or String-

3.rowSelection

  選擇功能的配置。

參數說明類型默認值
type多選/單選,checkbox?or?radioStringcheckbox
selectedRowKeys指定選中項的 key 數組,需要和 onChange 進行配合Array[]
onChange選中項發生變化的時的回調Function(selectedRowKeys, selectedRows)-
getCheckboxProps選擇框的默認屬性配置Function(record)-
onSelect用戶手動選擇/取消選擇某列的回調Function(record, selected, selectedRows)-
onSelectAll用戶手動選擇/取消選擇所有列的回調Function(selected, selectedRows, changeRows)-

五、數據獲取

  開始使用table組件時,不知道如何獲取這一行的數據,第一種方法是配置rowSelection,在onSelect函數被調用的時候,可以獲取當前行以及其子行的數據。第二種方法是配置Column中的render屬性,這個屬性對應一個函數,fun(text, record, index){}, 這是個渲染函數,參數分別為當前行的值,當前行數據,行索引,return可以決定表格里最終存放的值。

  本例中,表格中“操作”這一列就是通過render渲染實現,render時我們可以獲取到當前行數據的引用record,并為這一列的每個表格的內容綁定了點擊事件,點擊之后alert當前行的數據。效果如下圖所示。

六、博客新增標簽

?

  博客中新增了“打賞”標簽,就在右下方。前幾天看見一個博客有這樣的“打賞”標簽,于是模仿著做了一個,可以自行配置。由于是今天完成的,就在這里簡單的介紹一下如何在自己的博客里引用這個功能。

  進入自己的博客, 依次點擊“管理”, 設置。在“頁首Html代碼”中加入下面的引用。

<!-- 掃碼打賞 -->
<script type="text/javascript">window.reward_config={align: "right", top: "50%", animate: true, alipay: "http://images.cnblogs.com/cnblogs_com/hujunzheng/855447/o_alipay.jpg", webChat: "http://images.cnblogs.com/cnblogs_com/hujunzheng/855447/o_webChat.png"};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://files.cnblogs.com/files/hujunzheng/my_reward.js'];</script>

  注:注意支付方式要改成自己的,引用的my_reward.js可以下載到本地,然后存放到自己博客的文件管理中。

  更詳細的介紹請參考“打賞”標簽中的“了解更多”, 或者訪問 打賞demo?

轉載于:https://www.cnblogs.com/hujunzheng/p/5689650.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531294.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531294.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531294.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

解決“Dynamic Web Module 3.0 requires Java 1.6 or newer.”錯誤

一、問題描述 1.錯誤截圖如下。 2.設計的問題 在Eclipse中新建了一個Maven工程, 然后更改JDK版本為1.6, 結果每次使用Maven > Update project的時候JDK版本都恢復成1.5。 二、原因分析 Maven官方文檔有如下描述&#xff1a; 編譯器插件用來編譯項目的源文件.從3.0版本開始, …

java自定義注解類

一、前言 今天閱讀帆哥代碼的時候&#xff0c;看到了之前沒有見過的新東西, 比如java自定義注解類&#xff0c;如何獲取注解&#xff0c;如何反射內部類&#xff0c;this$0是什么意思? 于是乎&#xff0c;學習并整理了一下。 二、代碼示例 import java.lang.annotation.Elemen…

解決cookie跨域訪問

一、前言 隨著項目模塊越來越多&#xff0c;很多模塊現在都是獨立部署。模塊之間的交流有時可能會通過cookie來完成。比如說門戶和應用&#xff0c;分別部署在不同的機器或者web容器中&#xff0c;假如用戶登陸之后會在瀏覽器客戶端寫入cookie&#xff08;記錄著用戶上下文信息…

React使用antd Table生成層級多選組件

一、需求 用戶對不同的應用需要有不同的權限&#xff0c;用戶一般和角色關聯在一起&#xff0c;新建角色的時候會選擇該角色對應的應用&#xff0c;然后對應用分配權限。于是寫了一種實現的方式。首先應用是一個二級樹&#xff0c;一級表示的是應用分組&#xff0c;二級表示的是…

junit4進行單元測試

一、前言 提供服務的時候&#xff0c;為了保證服務的正確性&#xff0c;有時候需要編寫測試類驗證其正確性和可用性。以前的做法都是自己簡單寫一個控制層&#xff0c;然后在控制層里調用服務并測試&#xff0c;這樣做雖然能夠達到測試的目的&#xff0c;但是太不專業了。還是老…

快速搭建springmvc+spring data jpa工程

一、前言 這里簡單講述一下如何快速使用springmvc和spring data jpa搭建后臺開發工程&#xff0c;并提供了一個簡單的demo作為參考。 二、創建maven工程 http://www.cnblogs.com/hujunzheng/p/5450255.html 三、配置文件說明 1.application.properties jdbc.drivercom.mysql.jd…

dubbo服務提供與消費

一、前言 項目中用到了Dubbo&#xff0c;臨時抱大腿&#xff0c;學習了dubbo的簡單實用方法。現在就來總結一下dubbo如何提供服務&#xff0c;如何消費服務&#xff0c;并做了一個簡單的demo作為參考。 二、Dubbo是什么 Dubbo是一個分布式服務框架&#xff0c;致力于提供高性能…

git親測命令

一、Git新建本地分支與遠程分支關聯問題 git checkout -b branch_name origin/branch_name 或者 git branch --set-upstream branch_name origin/branch_name 或者 git branch branch_name git branch --set-upstream-toorigin/branch_name branch_name 二、查看本地分支所關…

mysql 7下載安裝及問題解決

mysql 7安裝及問題解決 一、mysql下載 下載地址&#xff1a;https://www.mysql.com/downloads/Community (GPL) DownloadsMySQL Community Server (GPL)Windows (x86, 64-bit), ZIP ArchiveNo thanks, just start my download.二、mysql安裝 解壓到指定目錄在mysql bin目錄下打…

RestTemplate發送請求并攜帶header信息

1、使用restTemplate的postForObject方法 注&#xff1a;目前沒有發現發送攜帶header信息的getForObject方法。 HttpHeaders headers new HttpHeaders(); Enumeration<String> headerNames request.getHeaderNames(); while (headerNames.hasMoreElements()) {String k…

工作中常用到的命令

linux zip 和 unzip http://blog.csdn.net/shenyunsese/article/details/17556089 linux 查看日志 http://blog.chinaunix.net/uid-15463753-id-2943532.html linux 刪除 http://www.jb51.net/LINUXjishu/179430.html linux查看末尾日志&#xff08;tail -f&#xff09; http:/…

tomcat開發遠程調試端口以及利用eclipse進行遠程調試

一、tomcat開發遠程調試端口 方法1 WIN系統 在catalina.bat里&#xff1a;   SET CATALINA_OPTS-server -Xdebug -Xnoagent -Djava.compilerNONE -Xrunjdwp:transportdt_socket,servery,suspendn,address8899   Linux系統 在catalina.sh里&#xff1a;   CATALINA_OPTS&q…

webpack+react+redux+es6開發模式

一、預備知識 node, npm, react, redux, es6, webpack 二、學習資源 ECMAScript 6入門 React和Redux的連接react-redux Redux 入門教程 redux middleware 詳解 Redux研究 React 入門實例教程 webpack學習demo NPM 使用介紹 三、工程搭建 之前有寫過 webpackreactes6開發模式…

fiddler發送post請求

1.指定為 post 請求&#xff0c;輸入 url Content-Type: application/x-www-form-urlencoded;charsetutf-8 request body中的參數格式&#xff1a;userNameadminicxp&userPassword123qwe!# 這種方式可以用 request.getParameter的方式來獲得。 2.指定為 post 請求&#xff…

基于spring注解AOP的異常處理

一、前言 項目剛剛開發的時候&#xff0c;并沒有做好充足的準備。開發到一定程度的時候才會想到還有一些問題沒有解決。就比如今天我要說的一個問題&#xff1a;異常的處理。寫程序的時候一般都會通過try...catch...finally對異常進行處理&#xff0c;但是我們真的能在寫程序的…

Kettle之數據抽取、轉換、裝載

Kettle 官網 ETL利器Kettle實戰應用解析系列 利用kettle組件導入excel文件到數據庫 kettle中實現動態SQL查詢 java中調用kettle轉換文件 kettle 7.x版本下載&#xff1a;https://pan.baidu.com/s/1nvnzzCH  密碼&#xff1a;6f5c mac 下運行spoon.sh,  windows下為spoon.bat…

webpack+react+redux+es6開發模式---續

一、前言 之前介紹了webpackreactreduxes6開發模式 &#xff0c;這個項目對于一個獨立的功能節點來說是沒有問題的。假如伴隨著源源不斷的需求&#xff0c;前段項目會涌現出更多的功能節點&#xff0c;需要獨立部署運行。為了更好地管理這些獨立的功能節點&#xff0c;我們需要…

JdbcTemplate使用小結

org.springframework.jdbc.core.JdbcTemplate.query(String sql, Object[] args, RowMapper<StaffUnionVO> rowMapper) throws DataAccessException 1.自定義rowMapper public class StaffUnionVO implements RowMapper<StaffUnionVO>, Serializable {private stat…

RabbitMQ安裝和使用(和Spring集成)

一、安裝Rabbit MQ   Rabbit MQ 是建立在強大的Erlang OTP平臺上&#xff0c;因此安裝Rabbit MQ的前提是安裝Erlang。通過下面兩個連接下載安裝3.2.3 版本&#xff1a; 下載并安裝 Eralng OTP For Windows (vR16B03)運行安裝 Rabbit MQ Server Windows Installer (v3.2.3)具體…

單點登錄實現(spring session+redis完成session共享)

一、前言 項目中用到的SSO&#xff0c;使用開源框架cas做的。簡單的了解了一下cas&#xff0c;并學習了一下 單點登錄的原理&#xff0c;有興趣的同學也可以學習一下&#xff0c;寫個demo玩一玩。 二、工程結構 我模擬了 sso的客戶端和sso的服務端&#xff0c; sso-core中主要是…