ruby-on-rails – Rails model.valid?刷新自定义错误并错误地返
发布时间:2020-12-16 20:46:54 所属栏目:百科 来源:网络整理
导读:我试图添加一个自定义错误到我的用户模型的实例,但是当我调用有效?它正在擦除自定义错误并返回true. [99] pry(main) u.email = "test@test.com""test@test.com"[100] pry(main) u.status = 11[101] pry(main) u.valid?true[102] pry(main) u.errors.add(:st
我试图添加一个自定义错误到我的用户模型的实例,但是当我调用有效?它正在擦除自定义错误并返回true.
[99] pry(main)> u.email = "test@test.com" "test@test.com" [100] pry(main)> u.status = 1 1 [101] pry(main)> u.valid? true [102] pry(main)> u.errors.add(:status,"must be YES or NO") [ [0] "must be YES or NO" ] [103] pry(main)> u.errors #<ActiveModel::Errors:[...]@messages={:status=>["must be YES or NO"]}> [104] pry(main)> u.valid? true [105] pry(main)> u.errors #<ActiveModel::Errors:[...]@messages={}> 如果我使用模型中的validate方法,那么它可以工作,但是这种特定的验证是从不同的方法(需要传递参数)中添加的: User def do_something_with(arg1,arg2) errors.add(:field,"etc") if arg1 != arg2 end 由于上述,user.valid?即使将该错误添加到实例,也会返回true. 解决方法
在ActiveModel中有效?定义如下:
def valid?(context = nil) current_context,self.validation_context = validation_context,context errors.clear run_validations! ensure self.validation_context = current_context end 所以现有的错误被清除是预期的.您必须将所有自定义验证放入一些有效的回调.喜欢这个: validate :check_status def check_status errors.add(:status,"must be YES or NO") unless ['YES','NO'].include?(status) end (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |