欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react中useState使用:如何實現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù)

 更新時間:2022年08月04日 16:47:27   作者:莫爾道嘎老范  
這篇文章主要介紹了react中useState的使用:如何實現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

如何實現(xiàn)在當(dāng)前表格直接更改數(shù)據(jù)

需求

用戶點擊修改按鈕時直接在彈出框的當(dāng)前頁面內(nèi)直接再次修改點擊行相關(guān)信息:

效果如下

點擊修改當(dāng)事人信息時,直接將當(dāng)前改為輸入框,并將信息展示,同時操作欄內(nèi)的內(nèi)容變?yōu)楸4婧腿∠?

具體做法

我這里是使用的antd組件內(nèi)的可編輯表格;當(dāng)然原生的也可以做,以前也做過;

這里的關(guān)鍵是點擊修改按鈕時,令當(dāng)前行的表格變?yōu)檩斎肟?,并展示?shù)據(jù);

給數(shù)據(jù)每一項加上 editable: true屬性,并通過該屬性控制 渲染的是數(shù)據(jù)還是可修改的輸入框

這里是使用的useState()方法來進行狀態(tài)控制的;

  • 關(guān)于 useState 的用法是,需要傳入一個參數(shù)作為狀態(tài)的初始值,當(dāng)函數(shù)執(zhí)行后會返回兩個值,一個是當(dāng)前狀態(tài)的屬性,一個是修改狀態(tài)的方法。
  • 使用方法更新數(shù)據(jù)后會觸發(fā)render()重新渲染數(shù)據(jù)
 const [editingKey, setEditingKey] = useState('');
    // 是否正在修改
    const isEditing = (record: Item) => record.key === editingKey;
    // 修改按鈕
    const edit = (record: Item) => {
        form.setFieldsValue({ ...record });
        setEditingKey(record.key);
    };
    // 取消
    const cancel = () => {
        setEditingKey('');
    };
    // 保存
    const save = async (id: React.Key) => {
        try {
            const row = (await form.validateFields())
            console.log('row', row)
            row.id = id
            onSave(row)
            setEditingKey('');
        } catch (err) {
            console.log(err)
        }
    };

我這里給useState一個初始值為空,點擊修改后使用setEditingKey()方法(useState返回的方法)將useState數(shù)據(jù)的值賦值為當(dāng)前行的唯一key值,這樣二者相等,就可以區(qū)別點擊的是哪一條數(shù)據(jù)的按鈕了;點擊取消setEditingKey(’’)重新置空;

判斷邏輯:

 // 是否正在修改
    const isEditing = (record: Item) => record.key === editingKey;

渲染數(shù)據(jù)前進行判斷:

 const mergedColumns = columns.map(col => {
        if (!col.editable) {
            return col;
        }
        return {
            ...col,
            onCell: (record: Item) => ({
                record,
                dataIndex: col.dataIndex,
                title: col.title,
                editing: isEditing(record),
            }),
        };
    });

根據(jù)數(shù)據(jù)狀態(tài)判斷渲染的是表格合適輸入框:

const EditableCell: React.FC<EditableCellProps> = ({
    editing,
    dataIndex,
    title,
    record,
    index,
    children,
    ...restProps
}) => {
    return (
        <td {...restProps}>
            {editing ? (
                <Form.Item
                    name={dataIndex}
                    style={{ margin: 0 }}
                    rules={[
                        {
                            required: true,
                            message: `請?zhí)顚?{title}!`,
                        },
                    ]}
                >
                    <Input />
                </Form.Item>
            ) : (
                    children
                )}
        </td>
    );
};

導(dǎo)出:

 return (
        <Form form={form} component={false}>
            <Table
                components={{
                    body: {
                        cell: EditableCell,
                    },
                }}
                bordered
                pagination={false}
                dataSource={dataSource}
                {...otherProps}
                columns={mergedColumns}
                rowClassName="editable-row"
            />
        </Form>
    );

其中dataSource為數(shù)據(jù)源,

功能實現(xiàn)。

useState修改對象的字段

首先定義一個空對象

  const [dataSelect, setDataSelect] = React.useState({})

給這個對象附上不同值,但不會把原來的覆蓋的掉

 const select = (e, item, type) => {
    const data = { ...dataSelect }
    if (type == 'price') {
      setSelectNO(e)
      data.min_price = item.min_price
      data.max_price = item.max_price
      setDataSelect(data)
      console.log(data)
      return
    }
    if (type == 'optionsCity') {
      setCity(e)
      data.city = item.text
      setDataSelect(data)
      console.log(data)
      return
    }
  }

原理用一個第三方的值,作為中間變量。每次都是附上最新的data。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • React如何使用create-react-app創(chuàng)建react項目

    React如何使用create-react-app創(chuàng)建react項目

    這篇文章主要介紹了React如何使用create-react-app創(chuàng)建react項目問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Rect Intersection判斷兩個矩形是否相交

    Rect Intersection判斷兩個矩形是否相交

    這篇文章主要為大家介紹了Rect Intersection判斷兩個矩形是否相交的算法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • 全棧輕量級搭配之Remix Prisma Sqlite使用分析

    全棧輕量級搭配之Remix Prisma Sqlite使用分析

    這篇文章主要為大家介紹了全棧輕量級搭配之Remix Prisma Sqlite使用示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • React為什么需要Scheduler調(diào)度器原理詳解

    React為什么需要Scheduler調(diào)度器原理詳解

    這篇文章主要為大家介紹了React為什么需要Scheduler調(diào)度器原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 在react-router4中進行代碼拆分的方法(基于webpack)

    在react-router4中進行代碼拆分的方法(基于webpack)

    這篇文章主要介紹了在react-router4中進行代碼拆分的方法(基于webpack),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • React實現(xiàn)倒計時功能組件

    React實現(xiàn)倒計時功能組件

    這篇文章主要為大家詳細(xì)介紹了如何通過React實現(xiàn)一個倒計時功能組件,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以了解下
    2023-09-09
  • React項目仿小紅書首頁保姆級實戰(zhàn)教程

    React項目仿小紅書首頁保姆級實戰(zhàn)教程

    React 是一個用于構(gòu)建用戶界面的 Javascript庫,接下來將通過實戰(zhàn)小紅書首頁的詳細(xì)介紹其設(shè)計思路和方法,將讀者帶入到react的開源世界,需要的朋友可以參考下
    2022-07-07
  • React useCallback鉤子的作用方法demo

    React useCallback鉤子的作用方法demo

    這篇文章主要為大家介紹了React useCallback鉤子的作用方法demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • React組件實例三大屬性state props refs使用詳解

    React組件實例三大屬性state props refs使用詳解

    這篇文章主要為大家介紹了React組件實例三大屬性state props refs使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • React useCallback詳細(xì)使用教程

    React useCallback詳細(xì)使用教程

    useCallback是react中比較重要的一個hook,useCallback 用來返回一個函數(shù),在父子組件傳參或者通用函數(shù)封裝中,起到舉足輕重的作用
    2022-11-11

最新評論