我有一個簡單的註冊端點,我希望允許用戶在我的 vue 應用程式中註冊,我還想從我的後端向 vue 用戶端顯示適當的錯誤。
錯誤 JSON 結構如下:
{ "errors": { "Password": [ "Password is required", "Minimum length of 8 characters is required" ], "UserName": [ "Username is required", "Minimum length of 6 characters is required" ], "EmailAddress": [ "Email Address is required", "Invalid Email Address" ], "ConfirmPassword": [ "Confirm Password is required" ] } }
我有一個帶有這樣的暫存器函數的可組合項:
export default function useAuth() { let errors = ref({}) const register = (request) => { errors = {} AuthService.register(request) .then(res => { console.log("res: "+ res) }) .catch(err => { const errList = err.response.data.errors; errors = errList // Here i'm getting a reponse console.log(errors) }) } return { register, errors } }
我還有一個表單元件,它只是一個添加了 v-models 的簡單表單:
<script> // Imports.. export default { components: {}, setup() { const { register, errors} = useAuth(); const request = { userName: "", emailAddress: "", password: "", confirmPassword: "", }; const handleSubmit = () => { register(request); // empty object console.log(errors) }; return { errors, request, handleSubmit }; }, }; </script>
在我的可組合項目中,我可以像這樣註銷錯誤回應
錯誤回應
我嘗試在表單元件中登出錯誤,但現在我只是得到一個空物件(我正在使用反應式來處理可組合項中的此錯誤物件)
來自可組合項目的空物件回應
看起來你正在回傳一個數組,而不是一個物件。
因此,要獲得存取權限,您需要執行
errors[0].Password
。您打算使用物件還是陣列(如果您有多個錯誤,可能會很有用)?
如果該陣列是預期的,並且您需要檢查
Password
屬性的所有錯誤,您將執行以下操作:反思你的程式碼
其中存在多個錯誤,使我很難提供適合您需求的簡潔答案。相反,我快速整理了一個根據您的原則工作的程式碼片段。展望未來,我將盡力強調需要注意的事項,並為未來提供一些好的建議。
- 使用
#的回應async function()
可以等待Promise
不好(如果您想立即使用結果,目前
console.log
證明使用async
)這並不能立即提供結果;它需要一些時間在單獨的執行緒上運行。結果,JavaScript 腳本幾乎立即向前移動。通常,如果您想立即使用結果,這將導致錯誤,因為回應尚未到達。
因此,當您嘗試存取
errors
的新結果時,您會看到它是空的,即使在console.log
之後,1-2 秒後,它不會再為空,因為register()
已經執行完畢。好的
等待
-等待進程結束 - MDN 文件非同步函數
- 需要什麼await
使用 - MDN 文件- 如何在 VueJS 上使用
ref()
?1.
將
ref()
、reactive()
、compulated()
等保存的值儲存在無法修改的變數中。宣告這些變數時始終使用 const。更多資訊 - StackOverflow 答案
不好
好的
2.
您在一個實例中使用
.value
後綴,而在另一個實例中則不使用。嗯,情況是ref()
變數的結果總是儲存在.value
中。您可以相應地操縱它。不好
好的
如何使用
ref()
? - VueJS 文件具有概述邏輯的範例程式碼
我對這些行進行了註釋,以便更好地理解程式碼。我希望這是可以理解的。