Есть ли способ вручную запустить анимацию isLoading из пользовательского действия в таблице материалов?
Я использую библиотеку материалов таблицы. Я хотел бы использовать текущую загрузочную анимацию, которую библиотека использует для пользовательской асинхронной операции. После нажатия на настраиваемое действие оно включается, а затем выключается, когда разрешается синхронизация.
import React from "react";
import MaterialTable from "material-table";
import ReactDOM from "react-dom";
import "./styles.css";
const handleAsync = () => {
// isLoading = true
// async done
// isLoading = false
}
function App() {
return (
<MaterialTable
columns={[
{
title: <button onClick={handleAsync}>async</button>
},
{
title: "Avatar",
field: "avatar",
render: rowData => (
<img
style={{ height: 36, borderRadius: "50%" }}
src={rowData.avatar}
/>
)
},
{ title: "Id", field: "id" },
{ title: "First Name", field: "first_name" },
{ title: "Last Name", field: "last_name" }
]}
data={query =>
new Promise((resolve, reject) => {
let url = "https://reqres.in/api/users?";
url += "per_page=" + query.pageSize;
url += "&page=" + (query.page + 1);
fetch(url)
.then(response => response.json())
.then(result => {
resolve({
data: result.data,
page: result.page - 1,
totalCount: result.total
});
});
})
}
title="Remote Data Example"
/>
);
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);
1 ответ
Решение
Ты можешь использовать isLoading
опора материала-таблицы. Именно так:
<MaterialTable
...//
isLoading={this.state.isLoading}
/>
Установите ваш state.isLoading=true перед асинхронной операцией, а затем установите его false после завершения операции