`
ywencn
  • 浏览: 87838 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

jQuery + Rails 快速实现用户注册AJAX验证

阅读更多

先上效果图吧!

 

验证标准方法分成了3个部分:

1 . 输入框失去焦点的时候验证并提醒,建立良好的用户体验。

2 . 表单提交前验证是否全部合格,确保数据符合要求。

3 . 模型层的验证。

 

这里说的用户注册AJAX验证主要是只离开用户名输入框焦点的时候即时提醒是否被占用。


 

 注册页面时用jquery插件thickbox展现的,这个不影响什么。

在验证用户是否被占用的时候,

使用jQuery的GET方式提交到users控制器的signup_login_check这个ACTION

之所以写成/users/signup_login_check/temp ,是因为我发现如果写/users/signup_login_check的话,

signup_login_check会被当成ID提交,action是show,改一下路由规则后应该是可以写成/users/signup_login_check的。

不然如果懒得改的话,写成/users/signup_login_check/temp 似乎也没什么害处,temp被按照默认路由解析成ID,也不起什么坏的作用。

 

这个是我的jQuery代码,以验证用户名为例。没用使用jquery的validate插件,我觉得直接写也没什么麻烦的。

先检查长度,符合要求再提交AJAX检查是否被占用。

 

 //开始验证输入的用户名
    $("input").focus(function(){
        $(this).setBlue();
    });
    $('#user_login').blur(function(){
        var login_length=$(this).val().length;
        if(login_length<=1 || login_length>=14){
            $(this).setRed("用户名为2-14个数字、字母、汉字");
        }
        else{
              $.get("/users/signup_login_check/temp",{
            user_login:$(this).val()
        },null,"script");
        };
    });

 

 这个是处理AJAX的ACTION

 def signup_login_check 
  	user=User.find_by_login(params[:user_login])
  	if user
      render  :js=> "$('#user_login').setRed('抱歉,该用户名已被占用');"
                else
      render  :js=> " $('#user_login').setGreen();"
  	end
  end

 

 上面有很多setRed  setGreen,这样命名其实不是很好,不过比较直观,其实是控制样式的jquery,代码如下

 $tip.addClass("errorFlag");

这个主要是用于按了提交按钮后来数有几个错误用的, errorFlag这个CSS类是空的,没有样式内容。

jQuery.fn.setRed=function(message){
        $(this).css("border-color",red);
        $tip=$(this).next();
        $tip.css("color",red);
        $tip.text(message);
        $tip.addClass("errorFlag");
        };
    jQuery.fn.setGreen=function(){
        $tip=$(this).next();
        $(this).css("border-color",green);
        $tip.css("color",green);
        $tip.html("<img src='/images/sign/alt.gif'>");
        $tip.removeClass("errorFlag");
    };

 

视图中的表单基本上是这样的:

<% form_for :user, :url => users_path ,:html=>{:id=>"usersignup"} do |f| -%>
        <table>
          <tr>
            <td >用户名:</td>
          </tr>
          <tr>
            <td ><%= f.text_field :login ,:class=>"sign_up_field"%>
              <em>用户名为2-14个数字、字母、汉字</em></td>
          </tr>
          <tr>
            <td >Email:</td>
          </tr>
          <tr>
            <td>
              <%= f.text_field :email,:class=>"sign_up_field" %>
              <em>Email将用于找回密码</em>
            </td>
          </tr>
          <tr>

 

提交前对所有文本框模拟的失去焦点,然后数有多少个errorFlag,这个是《锋利的jQuery》上介绍的做法,我直接搬过来了。

 //提交前的验证
    $("#send").click(function() {
        $("form :input").trigger('blur');
        var numError=$("form .errorFlag").length;
        if(numError>0){
            return false;
        }
    });

 

 

以上实现参考了 fsjoy1983 http://fsjoy.blog.51cto.com/318484/142351

他使用json返回数据,我用的js。而且他把验证ACTION放到INDEX里面了,这个做法不好。

 

还参考了 Ryan 的  http://railscasts.com/episodes/136-jquery 

他是用来处理留言,所以需要重新渲染的东西比较多,就集中放到 js.erb ,我只有1行数据需要返回,就直接写到控制器里了。

 

欢迎留言赐教!

  • 大小: 53.2 KB
分享到:
评论
8 楼 ywencn 2009-12-15  
rainchen 写道
用jquery,我大概会这样做(细节忽略):
用jquery,我大概会这样做(细节忽略):


额。。。似乎不错,学习了!
7 楼 rainchen 2009-12-15  
用jquery,我大概会这样做(细节忽略):

在b:
$("input").change(function(){
var $this = $(this);
$.getJSON('/users/new.json', {field, value}, functin(errors){
if(data.errors[$this.attr('name')]){
$this.addClass('fieldError');
}
})
});


在s:
# UsersController
def new
 @user = User.new(params[:user])
 respond_to do |format|
  format.html
  format.json { render :json => @user.valid? || @user.errors }
 end
end
6 楼 ywencn 2009-12-14  
supercode 写道
rails内置是propotype,集成性比较方便,默认的少敲了不少代码,不过jquery的插件实在是太丰富了。

propotype太没有ruby的风格啦!jQuery才像ruby风格嘛!
5 楼 ywencn 2009-12-14  
<div class="quote_title">wlon 写道</div>
<div class="quote_div">没人回,我来帮你顶顶人气。<img src="/images/smiles/icon_biggrin.gif" alt="">  不过我的ror还学得一塌糊涂,提不了什么意见。不过从Web开发角度来看,好像你的后端没做二次校验,这个是比较危险的。</div>
<p> </p>
<p>做了模型层的validate,那是最基本的。不然如果用户禁用了JS,就。。。。。</p>
4 楼 supercode 2009-12-14  
rails内置是propotype,集成性比较方便,默认的少敲了不少代码,不过jquery的插件实在是太丰富了。
3 楼 smallboby 2009-12-14  
我也用过rails,嘿嘿。。好久了,意见还真谈不上。
2 楼 wlon 2009-12-14  
没人回,我来帮你顶顶人气。  不过我的ror还学得一塌糊涂,提不了什么意见。不过从Web开发角度来看,好像你的后端没做二次校验,这个是比较危险的。
1 楼 ywencn 2009-12-13  
都是看帖不回帖的坏儿童

相关推荐

    Rails3+GithubOAuth2+设计示例应用程序_Ruby_JavaScript_下.zip

    3. **Devise**:Devise是一个灵活的身份验证解决方案,为Rails应用提供全面的认证管理,包括注册、登录、密码重置等。在OAuth2的场景下,Devise可以用来处理本地用户账户,并与OAuth2集成,提供更丰富的用户管理功能...

    Addison-Wesley - RailsSpace (Jul 2007)

    10. **Ajax和JavaScript**:探讨如何集成Ajax技术以实现页面无刷新更新,提升用户体验,以及如何使用Rails与JavaScript库(如jQuery)协同工作。 11. **部署**:最后,读者将学习如何将应用程序部署到服务器,如...

    deprecated-jquery-ajax-post-patch-fe:Rails-tic-tac-toe-api前端的框架

    井字游戏API要求用户注册然后登录以获得身份验证令牌。 我们将严重依赖curl , httpbin.org ,API和jQuery.ajax。 在课程结束时,我将讨论EventSource , Server Sent Events和包装器resourceWatcher 。 使用API...

    架构创新与演进(解决方案专场)——FreeWheel在微服务架构下的前端改造实践 共39页.pdf

    10. **容器管理和服务注册(Container Management & Service Registry)**:通过Docker等容器技术管理和部署微服务,利用服务注册中心实现服务发现。 11. **API网关(API Gateway)**:集成权限验证、限流、路由等功能,...

    登陆注册模版

    JavaScript还可以实现表单的异步提交,即AJAX(Asynchronous JavaScript and XML),这样用户在提交数据时无需等待页面刷新,提升用户体验。另外,JavaScript库和框架,如jQuery和React,提供了更便捷的方式来操作...

    LinkMe:Rails 个人项目

    此外,项目可能还涉及到用户认证和授权,Rails提供了Devise这样的gem来轻松处理用户的注册、登录、密码重置等功能。为了保证数据安全,项目可能使用bcrypt或scrypt等加密算法来存储用户密码。 在部署方面,LinkMe...

    inklab:用 Ruby 和 Rails 创建的讲故事游戏

    同时,它可能采用了Ajax技术来实现实时更新,这样用户在添加新故事线时无需刷新页面,增强了用户体验。 至于前端界面,inklab很可能使用了HTML、CSS和JavaScript,可能结合了Bootstrap等前端框架来快速构建响应式和...

    SpeechTherapy:Ruby on Rails 项目 - EDx SaaS 169.1x

    JavaScript可以实现动态加载、表单验证、AJAX请求等功能,提升用户体验。在“SpeechTherapy”中,可能有一个功能是通过JavaScript实现录音并上传到服务器,以供评估用户的发音。 控制器是模型和视图之间的桥梁,...

    个人博客系统

    在用户功能实现上,注册和登录功能涉及到用户身份验证,通常会使用哈希和盐值加密技术来保护用户的密码安全。发表博客则需要创建新的数据库记录,可能包括标题、内容、作者信息等字段。修改博客内容涉及数据库记录的...

    sample_app:Ruby on Rails教程:示例应用程序

    在"sample_app"中,你可能会学习如何实现用户注册、登录功能。这涉及到认证和授权。Rails提供了Devise这样的成熟Gem来处理用户身份验证,而Pundit或CanCanCan则可以帮助处理授权逻辑。 为了增强用户体验,你可能还...

    ror-codelit-landing:基于 ruby​​ on rails 的登陆页面

    在实际操作中,开发者可能还使用了 Bootstrap 或其他 CSS 框架来快速构建响应式布局,以及 Devise 或其他认证解决方案来处理用户注册、登录和授权。通过分析项目源码,我们可以深入理解 Ruby on Rails 如何与 ...

    Notebook:使用Ruby on Rails,HAML和CSS的笔记本应用

    5. Web应用的用户认证与授权:理解如何使用Rails的Devise或自定义解决方案来处理用户注册、登录和权限控制。 6. 数据存储与同步:可能涉及到JSON API的构建和使用,以及云服务(如AWS S3或Firebase)来实现跨设备的...

    sinatra-mailing-list-boilerplate:SinatraActiveRecord 邮件列表注册表单

    这个项目的核心功能是提供一个用户注册表单,用于订阅邮件列表。它集成了服务器端和客户端验证,确保数据的准确性和安全性,同时通过书面和视觉反馈提升用户体验。 ### Sinatra框架 Sinatra是一个用Ruby编写的微...

    Well-child-Space

    在"儿童空间"这样的问答网站中,用户注册、登录、发布问题、回答问题等功能都需要数据库支持。Rails的ActiveRecord简化了与数据库的交互,通过ORM(对象关系映射)将数据库表与Ruby类关联起来,使得数据操作如同操作...

    Pinterest:受 Pinterest 启发的 Web 应用程序

    4. **用户认证与授权**:为了实现类似 Pinterest 的功能,开发者需要实现用户注册、登录、身份验证以及权限管理。这可能通过 Devise 或其他认证库来实现,确保用户数据的安全。 5. **AJAX 和前端技术**:为了提供 ...

    Large:故事分享网站“中”的副本。

    JQuery AJAX调用用于所有数据库请求,而Jbuilder视图用于将返回的Ruby实例转换为JavaScript对象。 AWS集成用于存储和检索故事封面图像和缩略图。特征用户认证大型同时维护前端和后端用户身份验证。 客户端验证和...

    delish:健康甜点美食博客

    在这个博客中,Ruby可能被用来处理用户注册、登录、甜点配方的存储和检索,以及评论等互动功能。 标签提到的"JavaScript",是前端开发的重要语言,用于实现网页的动态效果和交互功能。在"delish:健康甜点美食博客...

    simple-login-web-app:具有本地和社交媒体登录功能的简单登录 Web 应用程序

    在"simple-login-web-app"中,可能使用了如OAuth2.0的版本,用户可以安全地通过Facebook、Google等服务进行授权,应用获取到访问令牌后,可以获取和更新用户信息,实现快速登录。 **后端架构** 虽然具体技术栈未明...

    java开源包3

    JOpenID是一个轻量级的OpenID 2.0 Java客户端,仅50KB+(含源代码),允许任何Web网站通过OpenID支持用户直接登录而无需注册,例如Google Account或Yahoo Account。 JActor的文件持久化组件 JFile JFile 是 JActor ...

    java开源包4

    JOpenID是一个轻量级的OpenID 2.0 Java客户端,仅50KB+(含源代码),允许任何Web网站通过OpenID支持用户直接登录而无需注册,例如Google Account或Yahoo Account。 JActor的文件持久化组件 JFile JFile 是 JActor ...

Global site tag (gtag.js) - Google Analytics