Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [jQuery] $.ajax()
Forum PHP.pl > Forum > XML, AJAX > AJAX
rulespl
Witam , mam mały problem

Oto kod:
Kod


$(function() {
              $('#butt').click(function() {
                  //asynchroniczne wysylanie wartosci z formularza do serwera
                
                  $.ajax({
                      type: "POST",
                      url: "pob_xml.php",
                      //data:"nazwa_g=costam" ,
                      data:"nazwa_g="+$('select').change(function() {
                                                     alert($(this).find(':selected').text());
                                                     alert($(this).val());
                                                     });
                      dataType: "xml",
                      success: function(xml) {
                          $(xml).find('row').each(function(){
              
                              // pobrane dane wrzuca do tabeli
                                  
                          }); //close each(
                      }
                  }); //close $.ajax(
              }); //close click(
          }); //close $


Mam problem z wysylanie danych od serwera otóż ma być wysyłana postem wartość z wybranego pola select option

  1. <select id="" name="nazwa_g">
  2. <option value="1">costam</option><option value="2">bleble</option>

Niestety nie działa, jesli wpisze dane na sztywno, tak jak to jest w zakomentowanej linijce:
Kod
     //data:"nazwa_g=costam" ,



wszystko śmiga jak trzeba

Pomóżcie plizzz ;]
korro
To nie tak.
Moim zdaniem obejdzie się bez zdarzenia change na selekcie nazwa_g, skoro wysyłasz dane po kliknięciu #butt.
Zdarzenie na selekcie wykona alerty, ale nie podstawi tam wartości.
Zamiast:
  1. <?php
  2. data:"nazwa_g="+$('select').change(function() {
  3.                                                     alert($(this).find(':selected').text());
  4.                                                     alert($(this).val());
  5.                                                     });
  6. ?>

spróbuj:
  1. <?php
  2. data:"nazwa_g="+$('nazwa_g :selected').text();
  3. ?>

Pozdrawiam.
rulespl
właśnie sprawdzałem niestety nie działa
może problem jest gdzieś z id-kami

Kod
<select id="firm" name="nazwa_g">
       <option value="1">Citigroup</option>
       <option value="2">Alcoa</option>
      
       </select>
       <input type="button" value="Pokaz;" id="butt">

questionmark.gif
korro
Podejrzewam, że może chodzić Ci o wysłanie value nie textu z selecta.
Wiec będzie tak:
  1. <?php
  2. data:"nazwa_g="+$("#firm").val();
  3. ?>
rulespl
nie nie chodzi o przesłanie wartosci pola czyli jak tam jest :Citigroup albo Alcoa

ogolnie jestem swiezy jesli chodzi o jQ, moze problem jest w tym że
Kod
$('#butt').click(function() {


odnosi sie do id=butt
a

$('nazwa_g :selected').text();

do czego innego, ale w sumie nie uzywam $(this)
nie wiem
korro
Ostatnia próba dziś:
  1. <?php
  2. data:"nazwa_g=" + $("#firm option[value='" + $("#firm").val() + "']").text()
  3. ?>
rulespl
Diała:
Kod
data:"nazwa_g=" + $("#firm option[value='" + $("#firm option").val() + "']").text(),


Możesz mi jeszcze powiedziec po co jest potrzebna wartość " value="


Wielkie dzieki
Pozdrawiam
korro
Błahostka.
Działają obie wersje i :selected i ta z value=, podawaliśmy zły selektor. Poprawny to #id.
rulespl
Kod
data:"nazwa_g="+$('#firm option :selected').text();


nie działa mi

nie rozumiem po co jest
Kod
[value='" + $("#firm option").val() + "']"

myślałem ze wystarczy:
Kod
data:"nazwa_g=" + $("#firm option").text(),


a jednak nie dziala sadsmiley02.gif
korro
To powinno:
Kod
data:"nazwa_g="+$("#firm :selected").text();
rulespl
działa i jest prostszy od poprzedniej wersji

jeszcze muszę trochę posiedzieć nad jQ, wielkie dzieki snitch.gif
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.