如何使React元件能夠記錄右鍵點擊的變量,需要雙擊才能實現
<p>我在我的專案中遇到了一個React元件的問題,當我在導航過程中需要點擊兩次才能正確記錄右鍵點擊的變數。以下是問題的詳細資訊和我的程式碼:</p>
<p>我有一個React元件,表示課程課程導航系統。當我在導航選單中點擊一個課程時,它應該記錄所點擊課程的索引並啟動某些操作。然而,我注意到我需要點擊兩次才能正確記錄索引。 </p>
<p>在元件內部,有一個名為handleOtp的函數,它處理啟動視訊播放和設定視訊存取OTP的邏輯。問題似乎源自於這個函數。 </p>
<p>以下是handleOtp函數的簡化概述:</p>
<pre class="lang-js prettyprint-override"><code>const handleOtp = async () => {
try {
const lessonId = course.lessons[clicked]?.video?.id;
// 這是有問題的區域
const { data } = await axios.post("/api/videoOtp", {
videoId: lessonId,
username: user.username,
ip,
});
if (!data.otp && !data.playbackInfo) {
return toast.error("影片OTP失敗!重新載入頁面");
}
loadVideo({
otp: data.otp,
playbackInfo: data.playbackInfo,
configuration: {
autoplay: true,
},
container: container.current,
});
} catch (err) {
console.error(err);
}
};
</code></pre>
<p>根據我的觀察,第一次點擊觸發了handleOtp函數,但點擊的索引錯誤,導致了意外的行為。第二次點擊最終記錄了正確的點擊索引,並按預期工作。 </p>
<p>我已確保沒有可能引起問題的非同步狀態更新。我懷疑可能存在一個時間或狀態管理問題導致了這種行為,但我很難確定確切的原因。 </p>
<p>我希望能夠理解為什麼會發生這種雙擊行為,以及如何確保在第一次點擊時記錄正確的點擊索引。非常感謝任何見解或建議。謝謝!</p>
<p>我的 React 元件:</p>
<pre class="brush:php;toolbar:false;"><StudentRoute>
<選單
defaultSelectedKeys={[點選]}
inlineCollapsed={折疊}
樣式={{高度:“100%”}}
>
{course.lessons.map((課程,索引) => (
<項目
onClick={async()==> {
setClicked(索引);
setIsLoading(true);
setSpin(真);
setCheckoutVisibility(“無”);
檢查交易狀態(索引);
setPaymentMethod("自助服務終端");
setKioskPhoneNumber("");
處理Otp();
}}
鍵={索引}
icon={<頭像>{索引1}頭像>}
></前>
<p>嘗試使用console.log記錄點擊的變數:</p>
全部回覆(1)我來回復
P粉8212313192023-08-16 16:58:48
這是因為setState
是非同步執行的。你在OnClick事件中設定了clicked
,然後呼叫了handleOtp
函數。在這種情況下,狀態還沒有更新,所以第一次點擊會得到錯誤的索引。
你只需要將index
當作參數傳遞給handleOtp
。不再需要setClicked
。
const handleOtp = async (index) => {}
<StudentRoute>
<div className="row mt-2">
<div className="lessons-menu">
<Menu
defaultSelectedKeys={[clicked]}
inlineCollapsed={collapsed}
style={{ height: "100%" }}
>
{course.lessons.map((lesson, index) => (
<Item
onClick={async () => {
setIsLoading(true);
setSpin(true);
setCheckoutVisibility("none");
checkTransactionStatus(index);
setPaymentMethod("kiosk");
setKioskPhoneNumber("");
handleOtp(index);
}}
key={index}
icon={<Avatar>{index + 1}</Avatar>}
/>
))}
<Menu/>
</div>
</div>
<StudentRoute/>
回覆
0 取消回覆