Skocz do zawartości
Zamknięcie Forum PC LAB

Szanowny Użytkowniku,

Informujemy, że za 30 dni tj. 30 listopada 2024 r. serwis internetowy Forum PC LAB zostanie zamknięty.

Administrator Serwisu Forum PC LAB - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie: wypowiada całość usług Serwisu Forum PC LAB z zachowaniem miesięcznego okresu wypowiedzenia.

Administrator Serwisu Forum PC LAB informuje, że:

  1. Z dniem 29 listopada 2024 r. zakończy się świadczenie wszystkich usług Serwisu Forum PC LAB. Ważną przyczyną uzasadniającą wypowiedzenie jest zamknięcie Serwisu Forum PC LAB
  2. Dotychczas zamowione przez Użytkownika usługi Serwisu Forum PC LAB będą świadczone w okresie wypowiedzenia tj. do dnia 29 listopada 2024 r.
  3. Po ogłoszeniu zamknięcia Serwisu Forum od dnia 30 października 2024 r. zakładanie nowych kont w serwisie Forum PC LAB nie będzie możliwe
  4. Wraz z zamknięciem Serwisu Forum PC LAB, tj. dnia 29 listopada 2024 r. nie będzie już dostępny katalog treści Forum PC LAB. Do tego czasu Użytkownicy Forum PC LAB mają dostęp do swoich treści w zakładce "Profil", gdzie mają możliwość ich skopiowania lub archiwizowania w formie screenshotów.
  5. Administrator danych osobowych Użytkowników - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie zapewnia realizację praw podmiotów danych osobowych przez cały okres świadczenia usług Serwisu Forum PC LAB. Szczegółowe informacje znajdziesz w Polityce Prywatności

Administrator informuje, iż wraz z zamknięciem Serwisu Forum PC LAB, dane osobowe Użytkowników Serwisu Forum PC LAB zostaną trwale usunięte ze względu na brak podstawy ich dalszego przetwarzania. Proces trwałego usuwania danych z kopii zapasowych może przekroczyć termin zamknięcia Forum PC LAB o kilka miesięcy. Wyjątek może stanowić przetwarzanie danych użytkownika do czasu zakończenia toczących się postepowań.

Temat został przeniesiony do archiwum

Ten temat przebywa obecnie w archiwum. Dodawanie nowych odpowiedzi zostało zablokowane.

Matt91111

[js] Problem z podmianą tekstu

Rekomendowane odpowiedzi

Staram się zrobić funkcję zmieniającą kolor znaków po najechaniu(mouseover),

moja funkcja działa w sposób następujący: odbiera tablice obiektów lettersToHighline,

function lettersToHighline(_letter, _color)
{
this.letter = _letter;
this.color = _color;
}

a następnie iteruje zawartość(tekst) i do spełniającego kryteria wstawia kod odpowiadający

za zmiane koloru tj:

function logo_HighlineMake(letters)
{	
var data = document.getElementById("logo-content").innerHTML;
var result = "";

var tagFound = false;

for(j = 0; j < data.length; j++) // iteracja
{
	// sprawdzanie tagow
	if(tagFound == false)
	{
		if(data[j] == "<")
		{
			tagFound = true;
			continue;
		}
	}
	else
	{
		if(data[j] != ">")
			continue;
		else
		{
			tagFound = false;
			continue;
		}
	}
               // sprawdzianie tagow

	//for(l = 0; l < letters.length; l++) // <-- pomysl ten polegal na iteracji obektow, z tym ze mnozyl ilosc tekstu * liczbe obiektow lettersToHighline
	//{
		if(data[j] == letters[l].letter) // jezeli obiekt spenia kryteria wstawia kod
			result = result + '<span style="color:' + letters[l].color + '">' + data[j] + '</span>';
		else result = result + data[j]; // jezeli nie nie wstawia i zostawia oryginalny
	//}

}

document.getElementById("logo-content").innerHTML = result; // podmiana zawartosci
}

 

Przed przerobieniem funckcja dla pojedynczych literek działała bez problemowo, z tym że za każdym wywołaniem mogłem podświetlić

tylko jedną literkę, a zależy mi na tym aby podczas jednego wywołania zmienić dowolną ilość na dowolny kolor

 

I nie mam pomysłu jak to ugryźć aby nie obciążyć zbytnio przeglądarki, funkcja która pozbywa się efektów "podświetlenia" działa bez problemów

 

Będę wdzięczny za każdą pomoc ;), z góry dzięki :)

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Dlaczego nie zrobić tego czystym css'em?:

<html>
<head>
<style>
.hoverowalny:hover {
  color: red;
}
</style>
</head>
<body>

<span class="hoverowalny"> dupa </span>

</body>
</html>

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Dlaczego nie zrobić tego czystym css'em?:

<html>
<head>
<style>
.hoverowalny:hover {
  color: red;
}
</style>
</head>
<body>

<span class="hoverowalny"> dupa </span>

</body>
</html>

 

No wiem że można tak, ale mnie nie o to chodzi, leci o to że przy wywołaniu funkcji zmienia kolor tylko znaków które zostały tam określone a resztę zostawia niezmienioną a w cssie leci wszystko, a pozatym różne znaki na różne kolory

 

przykładowe użycie:

function highlineSomeLetters
{
  var arLetters = [];
  arLetters.push(new lettersToHighline('A', red));
  arLetters.push(new lettersToHighline('B', blue));
  arLetters.push(new lettersToHighline('Z', grey}

  logo_HighlineMake(arLetters);
}

 

spodziewany rezultat

 <style>
  #logo-content
  {
    color:  black;
  }
 </style>

<div id="logo-content">
   <span style="color: blue;">B</span>olący <span style="color: grey;">Z</span>ą<span style="color: blue;">b</span>
</div>

 

Codzi o to aby reszta kodu pozostała bez zmian, czyli ustawiło tylko wybrane literki

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

1. posortować słowa malejąco długością

2. dla każdego z nich znaleźć położenie, jeżeli położenie się nakłada na wcześniejsze, to pominąć

3. posortować położenia malejąco

4. w pętli podmienić napisy

6. gotowe

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

  • Ostatnio przeglądający   0 użytkowników

    Brak zarejestrowanych użytkowników przeglądających tę stronę.

×
×
  • Dodaj nową pozycję...