jquery - 提交 Rails Jquery Modal 表单且验证不起作用

标签 jquery ruby-on-rails ajax ruby-on-rails-3

3 个并发问题:

  • 模式表单内联验证未显示
  • 模式表单未提交
  • 在哪里定义 ajax 之后发生的页面更改 提交? UJS文件,js根目录下的jquery等。

对于上下文,流程如下:

  1. 非用户点击“购买”按钮
  2. “transactions/form”模态表单打开:包含创建新交易和可选的新用户(注册)的表单
  3. 表单包含条纹信用卡字段和可选的密码/电子邮件字段,还包含有关帖子信息的隐藏字段(ID、价格等)
  4. 用户有两个选择: a. 仅输入信用详细信息 b.输入信用详细信息和密码/电子邮件,即注册
  5. 点击提交
  6. 如果:选项 a,仅输入信用详细信息
    • 验证卡
    • 信用卡扣款
    • 关闭模式并对页面进行适当的更改
  7. 如果:选项 b,已输入信用卡 + 注册详细信息
    • 验证卡和用户详细信息
    • 创建用户
    • 创建客户并向客户收费
    • 关闭模式并对页面进行适当的更改
  8. 帖子从“有效”更改为“无效”

我正在使用 client_side_validations gem。

按照上述步骤的大致顺序,以下是我的购买按钮、模态表单、jquery 和 Controller 的详细信息。

查看:发布带有购买按钮和模态表单的项目:

/button that opens modal form
%a.btn.buy-button{remote: :true,"data-toggle" => "modal", :href => "#buy_modal", :role => "button"} Buy

/the modal form
%div#buy_modal.modal{:role => "dialog",:style=>"display:none"}
  =render :partial => 'transactions/form'

模态形式:

  =form_for @transaction, :validate => true, :html => {:class => "form"} do |f|
    =yield(:user_validators)
    - if @user.errors.any?
      #error_explanation
      %h2= "#{pluralize(@user.errors.count, "error")} prohibited this group from being saved:"
      %ul
        - @user.errors.full_messages.each do |msg|
          %li= msg

    /POST DETAILS
    = f.hidden_field :stripe_card_token
    = f.hidden_field :price
    = f.hidden_field :tier_id
    = f.hidden_field :premium
    = f.hidden_field :notify_premium
    = f.hidden_field :user_id
    = f.hidden_field :customer_id
    /CREDIT CARD STUFF
    #credit-card{:style => @user.stripe_customer_id ? "display:none" : "display:block"}
      #credit-card-errors{:style => "display:none"}
        #stripe-error-message.alert-message.block-message.error
    %div.row-fluid
      = label_tag :credit_card_number
      = text_field_tag :credit_card_number, params[:credit_card_number], :class=>"credit-number span12"
    %div.row-fluid
      %div.span6
        = label_tag :expiry_date
        = date_select "", :expiry_date, {:discard_day => true, :order => [:month, :year], :use_month_numbers => true, :start_year => Date.today.year, :end_year => Date.today.year + 25}, {:class =>"credit-expiry inline"}
      %div.span3
      %div.span3.credit-cvv
        = label_tag :cvv, "CVV"
        = text_field_tag :cvv, params[:cvv], :class=>"credit-cvv input-block-level"

    /NEW USER STUFF
    =f.label :email
    =f.text_field :email
    =f.label :password
    =text_field_tag :password, params[:password]

    =f.submit "Save"

管理模式的 Jquery:

$(document).ready(function() {
  var $buy_dialog = $('#buy_modal').dialog({ 
    autoOpen: false, 
    title: 'Edit',
    modal: true,
    draggable: false,
    buttons: {
                "Save": function() {
                        $("#new_transaction").submit(function(){
                            var valuesToSubmit = $(this).serialize();
                            $.ajax({
                                url: $(this).attr('action'), //sumbits it to the given url of the form
                                data: valuesToSubmit,
                                type: 'POST',
                                dataType: "JSON" // you want a difference between normal and ajax-calls, and json is standard
                            }).success(function(json){
                                //act on result.
                            });
                            return false;
                        });
                        $('#buy_modal').dialog( "close" );
                },
                Cancel: function() {
                    $( this ).dialog( "close" );
                }
            }

    });

管理模式内联验证的 Jquery

$(document).ready(function(){
    $('.form').enableClientSideValidations();
    $('.form').on('shown', function() {
      $(ClientSideValidations.selectors.forms).validate();
    });
};

事务 Controller ,创建操作:

  def create
    @transaction = Transaction.new(params[:transaction])
    @user = User.new(:email => params[:transaction][:email], :password => params[:password])

    respond_to do |format|
      if params[:password]
        #let's make a user and a transaction object
        if @transaction.save
          @user.save_with_payment
          format.html { redirect_to @transaction, notice: 'Transaction was successfully created.' }
          format.json { render json: @transaction, status: :created, location: @transaction }
        else
          format.html { render action: "new" }
          format.json { render json: @transaction.errors, status: :unprocessable_entity }
        end
      else
        if @transaction.save
          @transaction.payment(params[:transaction][:tier_id],params[:transaction][:price],params[:transaction][:premium],params[:transaction][:premium_notify])
          format.html { redirect_to @transaction, notice: 'Transaction was successfully created.' }
          format.json { render json: @transaction, status: :created, location: @transaction }
        else
          format.html { render action: "new" }
          format.json { render json: @transaction.errors, status: :unprocessable_entity }
        end
      end
    end
  end

用户 Controller ,创建操作:

def create
    @user = User.new(params[:user])
    respond_to do |format|

      #OPTION A, explained above
      if params[:user][:password].nil?
        # Charge the card and don't make a user
        # get the credit card details submitted by the form
        token = params[:stripeToken]

        # create the charge on Stripe's servers - this will charge the user's card
        charge = Stripe::Charge.create(
          :amount => 1000, # amount in cents, again
          :currency => "usd",
          :card => token,
          :description => params[:email]
        )

      #OPTION B, explained above
      else
        # create user, customer, and charge them
        token = params[:stripeToken]
        if @user.save_with_payment(token)
          @user.payment()
          format.html { redirect_to @user, notice: 'User was successfully created.' }
          format.json { render json: @user, status: :created, location: @user }
        else
          #error message
          format.html { render action: "new" }
          format.json { render json: @user.errors, status: :unprocessable_entity }
        end
      end
    end
  end

我意识到这是一个庞大的问题,但这是一个非常常见的项目元素。我已经通过堆栈溢出来寻找每个组件的答案,但没有任何符合要求的。

Submit Form in Rails in a ajax way with jquery

Jquery modal windows and edit object

Jquery modal box form validations (试图重新发明轮子,而不是 rails ,并且指导不规范)

Problems validating form input in a modal window with jquery (这里没有 MVC,问题实际上没有得到解答)

client_side_validations gem with formtastic in jquery modal view not working (未回答)

最佳答案

部分答案:

模式表单内联验证未显示

无法帮助您解决这个问题

模式表单未提交

  • rails 具有内置的 CSRF 保护。您的请求很可能会因为您没有传递所需的 CSRF token 而被踢出
  • 您应该将 remote: true 添加到您的表单选项中。它将让不显眼的 Rails 驱动程序为您管理请求(不需要表单序列化),并根据响应触发自定义事件。请参阅Rails 3 remote links and forms或者只是 Rails AJAX guides了解更多信息

在哪里定义ajax提交后发生的页面更改? UJS文件,js根目录中的jquery等.

您可以使用 js.erb 文件进行响应,与 html.erb 文件相同,其中包含将在客户端上下文中执行的 jQuery 逻辑。

我试图更详细地回答这个问题,但你的逻辑非常复杂(我认为你在复制/粘贴过程中丢失了选项A中的一些语句,因为这个选项没有保存/格式)。附带说明一下,这种情况将使数据上下文交互架构变得相关。

关于jquery - 提交 Rails Jquery Modal 表单且验证不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15049353/

相关文章:

ruby-on-rails - Rails 根据表单输入重新加载 chartkick

php - 使用 AJAX 提交数据

c# - ASP.NET MVC 4 - 以 HTML、JSON 或 XML 响应的正确方式

javascript - 当选择菜单关闭或隐藏(从 View 中消失)时需要触发事件。我可以捕获哪个事件来完成此任务?

php - 使用变量作为高度和宽度的值

ruby-on-rails - Rails 连接表

javascript - var dump formdata as POST 返回 NULL

javascript - 将选定的值数组发送到 Controller - MVC

javascript - angularjs中的嵌入式虚拟键盘

ruby-on-rails - 从数组中删除键并使其持久的最快方法