Selesaikan Lebih Banyak Masalah Cangkuk: Panduan Mudah
P粉883278265
2023-08-14 13:19:01
<p>Saya menghadapi beberapa masalah dengan cangkuk dalam projek saya. Ini ialah fungsi yang menyemak kebenaran pengguna dan mengembalikan benar atau salah.</p>
<pre class="brush:php;toolbar:false;">import { useSelector } daripada "react-redux";
const CheckPermission = (kunci_modul, kunci_keizinan) => {
const { pengguna } = useSelector((negeri) => ({
pengguna: state.auth.user,
}));
const rolePermissions = pengguna?.role?.role_permissions ?? [];
const return_value = !!rolePermissions.find(
(p_senarai) =>
p_list.module?.key === module_key &&
p_list.permission?.key === permission_key
);
pulangkan nilai_pulangan;
};
eksport lalai CheckPermission;</pre>
<p>然后我在我的侧边栏组件中使用它</p>
<pre class="brush:php;toolbar:false;">const renderMenu = (menu, kunci) => {
jika (!CheckPermission(menu.moduleKey, menu.permissionKey)) {
kembali null;
}
kembali (
<Tooltip title={menu.name} placement="right" key={key}>
<NavLink
activeClassName={styles.active}
tepat
className={styles.item}
to={menu.path}
>
<span className={styles.iconBox}>{menu.icon}</span>
<span className={styles.itemText}> {menu.name}</span>
</NavLink>
</Petua alat>
);
};
eksport lalai ({ collapse, onCollapse, isAdmin }) => {
const { pengguna } = useSelector((negeri) => ({
pengguna: state.auth.user,
}));
kembali (
<Layout.Sider
tema = "cahaya"
className={classnames(styles.sider, collapse ? styles.collapsed : "")}
boleh dilipat
runtuh={runtuh}
onCollapse={onCollapse}
lebar={collapse ? 64 : 264}
onBreakpoint={() => {}}
titik putus = "xl"
gaya={{
limpahan: "auto",
ketinggian: "100vh",
kedudukan: "tetap",
kiri: 0,
atas: 0,
paddingTop: "50px",
}}
>
<div className={styles.action}>
{pengguna && pengguna.baca_sahaja
? menus.map((menu, i) => {
if (menu.name === "Харилцагч") {
return renderMenu(menu, i);
} lain {
kembali (
menu &&
menu.kanak-kanak &&
// eslint-disable-next-line array-callback-return
menu.children.map((submenu, j) => {
if (submenu.name === "QR данс") {
kembali (
<div key={i} className={styles.parentnav}>
{renderMenu(submenu, j)}
</div>
);
}
})
);
}
})
: menus.map((menu, i) => {
jika (menu.path) {
return renderMenu(menu, i);
} lain {
kembali (
<div key={i} className={styles.parentnav}>
{menu.name ? (
<div
className={`${styles.navlabel} ${styles.partentText}`}
>
{menu.name}
</div>
): null}
{menu.children.map((submenu, j) => {
jika (!submenu.path) mengembalikan null;
if (isAdmin) {
return renderMenu(submenu, j);
} lain {
kembali null;
}
})}
</div>
);
}
})}
</div>
</Layout.Sider>
);
};</pre>
<p>但是它抛出了"Ralat: Diberikan lebih banyak cangkuk berbanding semasa pemaparan sebelumnya.",我该如何在其他地方正确使用我的checkPermission函数。
<p>我尝试在循环中使用checkPermission函数,结果是一样的。</p>
"Ralat: Rendering dengan lebih banyak cangkuk daripada paparan terakhir" biasanya berlaku apabila anda menggunakan cangkuk React (seperti useSelector) dengan cara yang melanggar peraturan cangkuk. Peraturan menyatakan bahawa cangkuk mesti sentiasa dipanggil pada tahap teratas komponen berfungsi, dan bukan dalam gelung, bersyarat atau fungsi bersarang. Dalam kod anda, anda nampaknya menggunakan fungsi CheckPermission dalam gelung dan bersyarat.