VueJS 处理表单组件上 api 调用的错误
P粉964682904
P粉964682904 2023-09-06 22:01:08
[Vue.js讨论组]

我有一个简单的注册端点,我希望允许用户在我的 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 的简单表单:

在我的可组合项中,我可以像这样注销错误响应

错误响应

我尝试在表单组件中注销错误,但现在我只是得到一个空对象(我正在使用反应式来处理可组合项中的此错误对象)

来自可组合项的空对象响应

P粉964682904
P粉964682904

全部回复(1)
P粉576184933

看起来你正在返回一个数组,而不是一个对象。

因此,要获得访问权限,您需要执行errors[0].Password

您打算使用对象还是数组(如果您有多个错误,可能会很有用)?

如果该数组是预期的,并且您需要检查 Password 属性的所有错误,您将执行如下操作:

errors.find(err => !!err.Password).Password
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号