加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

关于Ruby on Rails视图编写的一些建议

发布时间:2020-12-16 22:26:45 所属栏目:百科 来源:网络整理
导读:不要直接从视图调用模型层。 不要在视图构造复杂的格式,把它们输出到视图 helper 的一个方法或是模型。 使用 partial 模版与布局来减少重复的代码。 加入 client side validation 至惯用的 validators。 要做的步骤有: 声明一个由 ClientSideValidations::


    不要直接从视图调用模型层。
    不要在视图构造复杂的格式,把它们输出到视图 helper 的一个方法或是模型。
    使用 partial 模版与布局来减少重复的代码。

    加入 client side validation 至惯用的 validators。 要做的步骤有:

        声明一个由 ClientSideValidations::Middleware::Base 而来的自定 validator

      

 module ClientSideValidations::Middleware
   class Email < Base
   def response
    if request.params[:email] =~ /^([^@s]+)@((?:[-a-z0-9]+.)+[a-z]{2,})$/i
    self.status = 200
    else
    self.status = 404
    end
    super
   end
   end
  end

        建立一个新文件public/javascripts/rails.validations.custom.js.coffee 并在你的 application.js.coffee 文件加入一个它的参照:

  
  # app/assets/javascripts/application.js.coffee
  #= require rails.validations.custom

        添加你的用户端 validator:

  #public/javascripts/rails.validations.custom.js.coffee
  clientSideValidations.validators.remote['email'] = (element,options) ->
   if $.ajax({
   url: '/validators/email.json',data: { email: element.val() },async: false
   }).status == 404
   return options.message || 'invalid e-mail format'


(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读