Jquery Ajax reakci na koleje se vrací nedefinované údaje

0

Otázka

Snažím se používat ajax tak pouze částečné načte a ne celé webové stránky, ale data se vrací undefined. Dělám něco špatně? Tady je kód:

/* form.js */

$(document).ready(() => {
  $('#stock-lookup-form').on('ajax:complete', (e, data, status) => {
    /*$('#results').html(data.responseText)*/
    console.log(data) /* --> this returns undefined*/
  }) 
})

/* stocks_controller.rb */

class StocksController < ApplicationController
  def search
    if params[:stock].present?
      @stock = Stock.new_from_lookup(params[:stock])
      if @stock
        render partial: 'users/result'
      else
        flash[:danger] = "You have entered an incorrect symbol"
        redirect_to my_portfolio_path
      end
    else 
      flash[:danger] = "You have entered an empty search string"
      redirect_to my_portfolio_path
    end
  end
end

/* výsledek.html.erb částečné */

<%if @stock%>
  <div class="well results-block">
    <strong>Symbol: </strong><%[email protected]%>
    <strong>Name: </strong><%[email protected]%>
    <strong>Last price: </strong><%[email protected]_price%>
  </div>
<%end%>

/* my_portfolio.html.erb (kde je umístěn formulář) */

<h1>My portfolio</h1>

<h3>Search for stocks</h3>
<div id="stock-lookup">
  <%=form_tag search_stocks_path, remote: true, method: :get, id: 'stock-lookup-form' do%>
    <div class="form-group row no-padding text-center col-md-12">
      <div class="col-md-10">
        <%=text_field_tag :stock, params[:stock], placeholder:'Stock ticker symbol', autofocus:true, class:'form-control search-box input-lg'%>
      </div>
      <div class="col-md-2">
        <%=button_tag(type: :submit, class:'btn btn-lg btn-success', id:'search-btn') do%>
          <i class="fa fa-search"></i> Look up a stock
        <%end%>
      </div>
    </div>
  <%end%>
</div>
<div id="results">
  <%=render 'users/result'%>
</div>

ajax html javascript jquery
2021-11-23 21:35:27
1

Nejlepší odpověď

0

[] Podpis volání do UJS je obslužné rutiny událostí se změnil. Na rozdíl od verze s jQuery, všechny vlastní akce vrátit pouze jeden parametr: události. V tomto parametru, je další atribut detail, který obsahuje celou řadu dalších parametrů. https://guides.rubyonrails.org/working_with_javascript_in_rails.html#rails-ujs-event-handlers

$(document).ready(() => {
  $('#stock-lookup-form').on('ajax:complete', (event) => {
    const [data, status, xhr] = event.detail;
    console.log(data);
  });
});
2021-11-23 21:44:05

Aha to jsem nevěděl, děkuji moc!!! Budu se snažit, co nejdříve je to možné
Ale Yanczuk

V jiných jazycích

Tato stránka je v jiných jazycích

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................