不要直接從視圖調用模型層。
不要在視圖構造複雜的格式,把它們輸出到視圖 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'