Rails-jQuery为什么我必须单击两次才能显示jQuery效果?

时间:2015-03-15 06:01:47

标签: javascript jquery ruby-on-rails ruby-on-rails-4

我正在使用Rails 4.1.1为什么我必须单击两次才能显示jQuery效果? 我一直在谷歌搜索,但我找不到任何解决方案,不确定我的jQuery代码是否有问题或....

当我第一次点击“提交”时,效果没有出现,但是已经调用了POST动作,当我第二次点击时,效果出现并调用了POST动作。

请在我的create.js.erbusers_controller.rbnew.html.erb

下方查看

create.js.erb

function isValidEmailAddress(emailAddress) {
  var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i);
  return pattern.test(emailAddress);
};

$("form").submit(function( event ) {
  var email = $("input#user_email").val();
if (email == "") {
$("h1").text( "Email cannot be empty" ).show().fadeOut( 3000 );
return;
} else if (!isValidEmailAddress(email)) {
$("h1").text( "Email address is not valid" ).show().fadeOut( 3000 );
}else {
  $("h1").text( "Correct email address" ).show();
}
event.preventDefault();
});

new.html.erb

<%= form_for @user, remote: true do |f| %>
  <p>
    <%= f.text_field :email %>
  </p>

  <p>
    <%= f.submit :Submit %>
  </p>
<% end %>
<h1></h1>

  <% @users.each do |user| %>
    <tr>
      <li><%= user.email %></li>
    </tr>
  <% end %>

users_controller.rb

class UsersController < ApplicationController

  def new
    @users = User.all
    @user = User.new
  end

  def create
    @user = User.new(user_params)
    respond_to do |format|
      format.html { redirect_to '/' }
      format.js
      end   
    @user.save
  end

private

  def user_params
    params.require(:user).permit(:email)
  end

end

2 个答案:

答案 0 :(得分:2)

Turbo链接可能导致此问题 - 禁用您应用中的turbo链接,这对我有用过去我遇到类似问题

答案 1 :(得分:1)

你的过程是错误的。当您在Rails中提交远程表单时,应用程序会向create操作发送一个AJAX请求,然后从您的create.js.erb中删除收到的js代码。因此,第一次单击按钮时,没有任何反应。

js视图不是处理验证的地方,你应该把它放在assets/javascripts的某个地方。 js视图是用表格更新页面的html视图的地方(例如,将记录添加到列表中,显示收到的错误,重置表单)。