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

标签 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

最佳答案

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

关于javascript - Rails-jQuery 为什么我必须点击两次才能显示 jQuery 效果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29057730/

相关文章:

javascript - Knockout.js:如何获取当前表单?

css - 将类添加到我使用 ajax() jquery 方法获取的每个数据

javascript - 切换可丢弃

ruby-on-rails - 使用'counter_cache'时如何调用after_save回调?

c# - parseInt 如何获取它的值

java - 来自 Java 的音频流不工作,但视频工作正常

ruby-on-rails - 使用 postgres 让 webrick 服务器在端口 80 上运行

ruby-on-rails - 如何使用 Ruby on Rails 中的映射表跟踪模型历史?

javascript - WebSql : transaction does rollback if size limit is reached

javascript - 使用 crypto 模块进行 Node.js MD5 解密