如何使用 primereact 中的 Splitbutton 获取数据表行数据/对象
我对 ReactJs 和 ReactJs 还很陌生。尝试做一个项目来学习。我正在使用 PrimeReact UI 组件库。一切工作正常,但在将行数据访问到函数中时面临问题。
参考 - https://www.primefaces.org/primereact/splitbutton/
如果我点击在操作按钮上,然后它显示数据
请帮助我。提前致谢。
import { DataTable } from "primereact/datatable";
import { SplitButton } from "primereact/splitbutton";
/* split button items*/
const items = [
{
label: "Update",
icon: "pi pi-refresh",
command: (e) => {
console.log(this);
console.log(e); /* Need to receive row data here */
/* I am getting {item:{label: 'Update',icon: 'pi pi-refresh',command: (e) },originalEvent:{...}} I have check originalEvent.target but no data is there */
},
},
{
label: "Delete",
icon: "pi pi-times",
command: (e) => {
console.log(this);
console.log(e); /* Need to receive row data here */
},
},
];
/* data to show */
const griddata = [
{
name: "Tivaprasad Reddy",
employeeId: "da9d1448-e1bd-4dad-9d57-dddf655c8ecf",
mobile: "7099111460",
Status: "SCREENING",
addedBy: "anil kumar",
addedOn: "2022-02-22T15:04:00.382+00:00",
},
{
name: "Mukesh Bhutani",
employeeId: "bcdefa7a-6c4d-4ac1-bd6d-025e88e08f62",
mobile: "9582111515",
Status: "SCREENING",
addedBy: "anil kumar",
addedOn: "2022-02-22T15:05:02.416+00:00",
},
];
const splitBtn = (d) => {
console.log(d); /* Getting data here*/
};
const buttonTemplate = (data) => (
<>
<SplitButton
label="Action"
className="p-button-sm"
model={items}
onClick={(e) => splitBtn(data)}
></SplitButton>
</>
);
return (
<div>
<div className="card">
<DataTable
value={griddata}
scrollable
scrollHeight="500px"
responsiveLayout="scroll"
>
<Column field="name" header="Name"></Column>
<Column field="Title" header="Title"></Column>
<Column field="Status" header="Status"></Column>
{/* <Column field="Action" header="Action" body={editTemplate}></Column> */}
<Column field="Action" header="Action" body={buttonTemplate}></Column>
</DataTable>
</div>
</div>
);
I am pretty new to ReactJs & trying to make a project to learn. I am using PrimeReact UI Component Library. Everything is working fine but facing issue with accessing row data into functions.
Reference - https://www.primefaces.org/primereact/splitbutton/
If I click on action button then it is showing data
Please help me out in this. Thanks in Advance.
import { DataTable } from "primereact/datatable";
import { SplitButton } from "primereact/splitbutton";
/* split button items*/
const items = [
{
label: "Update",
icon: "pi pi-refresh",
command: (e) => {
console.log(this);
console.log(e); /* Need to receive row data here */
/* I am getting {item:{label: 'Update',icon: 'pi pi-refresh',command: (e) },originalEvent:{...}} I have check originalEvent.target but no data is there */
},
},
{
label: "Delete",
icon: "pi pi-times",
command: (e) => {
console.log(this);
console.log(e); /* Need to receive row data here */
},
},
];
/* data to show */
const griddata = [
{
name: "Tivaprasad Reddy",
employeeId: "da9d1448-e1bd-4dad-9d57-dddf655c8ecf",
mobile: "7099111460",
Status: "SCREENING",
addedBy: "anil kumar",
addedOn: "2022-02-22T15:04:00.382+00:00",
},
{
name: "Mukesh Bhutani",
employeeId: "bcdefa7a-6c4d-4ac1-bd6d-025e88e08f62",
mobile: "9582111515",
Status: "SCREENING",
addedBy: "anil kumar",
addedOn: "2022-02-22T15:05:02.416+00:00",
},
];
const splitBtn = (d) => {
console.log(d); /* Getting data here*/
};
const buttonTemplate = (data) => (
<>
<SplitButton
label="Action"
className="p-button-sm"
model={items}
onClick={(e) => splitBtn(data)}
></SplitButton>
</>
);
return (
<div>
<div className="card">
<DataTable
value={griddata}
scrollable
scrollHeight="500px"
responsiveLayout="scroll"
>
<Column field="name" header="Name"></Column>
<Column field="Title" header="Title"></Column>
<Column field="Status" header="Status"></Column>
{/* <Column field="Action" header="Action" body={editTemplate}></Column> */}
<Column field="Action" header="Action" body={buttonTemplate}></Column>
</DataTable>
</div>
</div>
);
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
这也让我困惑了一段时间,直到我意识到它实际上非常简单:')
您只需使用“Column”元素的“body”属性的回调函数中的“rowData”参数即可。
这里
“buttonTemplate”回调函数已经携带了行数据并将其呈现在第一个参数。因此,将“items”变量转换为一个函数,将“data”参数传递给您的项目,就像这样
我希望这对您有所帮助
This confused me for a while too until I came to realize it was actually pretty simple :')
You just have to use the "rowData" parameter that comes in the callback function of the "body" property of the "Column" element.
Here
<Column field="Action" header="Action" body={buttonTemplate}></Column>
the "buttonTemplate" callback function is already carrying the row data and presenting it in the first parameter.So convert the "items" variable into a function that passes over that "data" parameter to your items just like this
I hope this has been helpful
有多个数据表属性,您可以使用 onRowClick() 来实现此目的。
现在,您可以使用在行单击时使用的状态变量来获取行数据。
There are several datatable properties and you can use to achieve this by using onRowClick().
Now you can get your row data by using the state variable you have used on row click.
你可以这样走(PrimeReact):
感谢@Ahmed Hassan 的想法
You can go this way (PrimeReact):
Thanks @Ahmed Hassan for his idea
如果您正在寻找 primeng 解决方案:
In case your looking for primeng solution: