• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

skrypt js w pętli php

VPS Starter Arubacloud
0 głosów
510 wizyt
pytanie zadane 26 grudnia 2017 w JavaScript przez mi-20 Stary wyjadacz (13,190 p.)

Witam, podobny problem był już na forum jednak nie ma tam odpowiedzi która mnie zadowala więc zadam pytanie jeszcze raz :)

Otóż, mam pętle php która wyświetla kilka produktów na stronie. W każdym okienku jest przycisk "+". Jeśli najedziemy myszką na przycisk obok ma pokazać się okienko "Dodaj do koszyka". W jQuery osiągnąłem ten efekt w taki sposób:

$(document).ready(function()
{
    $('#Show').mouseover(function(){
        $('#plus').toggle();
    });
});

Problemem jest jednak to że produkty wyświetla pętla i jest ich kilka, id(#) ma być unikatowe a po wyświetleniu w pętli nie jest i mój skrypt działa tylko dla pierwszego elementu pętli, dla pozostałych nie istnieje.

Moje pytanie brzmi: jakiej funkcji jQuery użyć lub jak osiągnąć efekt w którym skrypt będzie działał dla każdego elementu w pętli? Myślałem żeby użyć klas zamiast id jednak wtedy po najechaniu na jeden przycisk działało by to dla wszystkich elementów.

Dzięki :)

1 odpowiedź

0 głosów
odpowiedź 26 grudnia 2017 przez Fenix Nałogowiec (26,750 p.)
wybrane 26 grudnia 2017 przez mi-20
 
Najlepsza

To po użyciu class, żeby nie działało na wszystkich elementach, przekaż do funkcji referencje do obiektu na który najechałeś myszką. W bibliotece $ służy do tego this. 

komentarz 26 grudnia 2017 przez mi-20 Stary wyjadacz (13,190 p.)

Kod z użyciem klas wyglądałby tak:

$(document).ready(function()
{
    $('.class').mouseover(function(){
        $('.class1').toggle();
    });
});

i  w którym miejscu powinno być $(this) żeby to działało?

1
komentarz 26 grudnia 2017 przez Fenix Nałogowiec (26,750 p.)
z ".class" powininieneś poprzez this uruchomić element (w środku niego?) class1. Pokaz Kod html.
komentarz 26 grudnia 2017 przez mi-20 Stary wyjadacz (13,190 p.)
1
komentarz 26 grudnia 2017 przez Fenix Nałogowiec (26,750 p.)
Na Twoim miejscu zmieniłbym strukturę html. Na obecnej z wykorzystaniem $, proponuję: https://codepen.io/anon/pen/KZaXvz Dzięki $(this) odnoszę się do elementu na który trafiła mysz, następnie używam funkcji next(), ona daje mi referencję do następnego elementu (sąsiada) w hierarchi DOM, i to na nim wykonuje toggle().

Podobne pytania

0 głosów
1 odpowiedź 314 wizyt
pytanie zadane 3 października 2018 w JavaScript przez kakaka1 Nowicjusz (120 p.)
0 głosów
3 odpowiedzi 190 wizyt
pytanie zadane 22 grudnia 2016 w PHP przez powrooz666 Początkujący (300 p.)
+5 głosów
1 odpowiedź 550 wizyt
pytanie zadane 17 maja 2015 w JavaScript przez Comandeer Guru (599,730 p.)

92,454 zapytań

141,262 odpowiedzi

319,089 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...