gpt4 book ai didi

javascript - Reactjs触发onClick函数而不点击功能组件

转载 作者:行者123 更新时间:2023-12-05 08:38:24 26 4
gpt4 key购买 nike

我在 React js 中使用功能组件,我的 onClick 函数触发了组件渲染,而无需单击我的 li 元素;这是我的父组件,它将 handleCallDetails 函数作为 props 传递给子组件:

export default function Cartable(){

const [items , setItems] = useState(null);
const [details , setDetails] = useState(null);



function handleCallDetails(id){
if(items !== null && details === null){
let d = items.find(x => {
return x.id === id;
});

}
}

useEffect(() => {
axios.get(`/workflows/${mode}` ,{
params : {
OrganizationId : "FE905B40-DA6E-4A81-8A4F-B447AA6B0EA3" ,
Type : 2 ,
sortorder : "desc" ,
pageIndedx : 1 ,
pageSize : 10
}
}).then(response => {
// console.log('response : ***************** ' , response);
setItems(response.data.data);
}).catch(error => {
console.log('error : ****************** ' , error);
});
} , [mode]);



return (
<Grid container spacing={2}>
<Grid item xs={12} sm={4} md={3}>
<div className="drt_RightSide drt_segment">
<h4 className="drt_RightSideTitle">
<i className="far fa-inbox"></i>
کارتابل
</h4>
<ul>
{/* <li>
<i class="far fa-inbox"></i>
<span>درخواست ها</span>
</li> */}
<li onClick={() => {setMode('pending');}}>
<i className="fas fa-exclamation"></i>
<span><FormattedMessage id="CARTABLE_PENDING" /></span>
<span className="drt_badge_warning drt_NotifNum">5</span>
</li>
<li onClick={() => {setMode('approved');}}>
<i className="far fa-check"></i>
<span>تایید شده</span>
</li>
<li onClick={() => {setMode('rejected');}}>
<i className="far fa-times"></i>
<span>رد شده</span>
<span className="drt_badge_error drt_NotifNum">7</span>
</li>
<li>
<i className="far fa-bell"></i>
<span>خارج از فرآیند</span>
</li>
</ul>
</div>
</Grid>
<Grid item xs={12} sm={8} md={9}>
<div className="drt_LeftSide drt_segment"> */}

{/* cartbale list */}
<CartableList
items={items}
callDetails={handleCallDetails}/>

</div>
</Grid>
</Grid>
);

}

我的子组件使用名为 callDetails 的 onClick 函数:

export default function CartableList(props){

const [showbox , setShowbox] = useState(false);
const [age, setAge] = useState('');

const handleChange = (event) => {
setAge(event.target.value);
};

function handleFilterBox(){
setShowbox(!showbox);
}


return (
<Fragment>

{/* cartable list */}
<div style={{direction : "ltr"}}>
<Scrollbars style={{ height: 400 }}>

{
props.items && props.items !== undefined ?
props.items.map(function(item , index){

return (
<div className="drt_clearfix drt_CartableItem" key={index} onClick={(props.callDetails)(item.id)}>
{/* <div className={clsx(drt_ItemStar , item.star ? drt_IsStared : '')}>
<span><i className={clsx(item.star ? "fas fa-star" : "fal fa-star")}></i></span>
</div> */}
<div className="drt_ItemImg">
<span>
<img alt={userImg} src={item.pictureUrl !== undefined && item.pictureUrl !== null ? item.image : userImg} />
</span>
</div>
<div className={clsx("drt_ItemName" , !item.isSeen ? "drt_IsNotSeen" : '')}>
{item.issuerFirstName}
<br />
{item.issuerLastname}
</div>
<div className="drt_ItemIcon">
<Tooltip title={(props.moduleType)(item.type).name}>
<span className={item.isSeen ? "drt_badge_default" : "drt_badge_primary"}>
<i className={(props.moduleType)(item.type).icon} />
</span>
</Tooltip>
</div>
<div className={clsx("drt_ItemDesc" , !item.isSeen ? "drt_IsNotSeen" : '')}>
{item.objectTitle}
</div>
<div className="drt_ItemStatus">
<span className={(props.stateClass)(item.status)}>
{(props.stateTitle)(item.status)}
</span>
</div>
<div className={clsx("drt_ItemDate" , !item.isSeen ? "drt_IsNotSeen" : '')}>
<p>
<span>
{item.issuerTime}
</span>
<span>
{item.issuerDate}
</span>
</p>
<i className="fal fa-clock" />
</div>
</div>
);
}) : ''
}

</Scrollbars>
</div>
</Fragment>
);

}

请帮助我解决这个问题,而不是将我的功能组件转换为类组件并绑定(bind)我的功能

最佳答案

正确的做法是这样的。你需要使用箭头函数,否则 react 会明白你想在加载时执行函数

错误

<div className="drt_clearfix drt_CartableItem" key={index} onClick={(props.callDetails)(item.id)}>

正确

<div className="drt_clearfix drt_CartableItem" key={index} onClick={() => props.callDetails(item.id)}>

关于javascript - Reactjs触发onClick函数而不点击功能组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62891174/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com