str_replace() v praxi
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

str_replace() v praxistr_replace() v praxi

 

str_replace() v praxi

Google       Google       13. 4. 2006       12 741×

Formátovanie textu a smajlíci v príspevkoch na diskusných fórach sú dnes veľmi časté javy a ak chcete vedieť, ako na to, pozrite si návod vhodný aj pre ľudí s malými znalosťami PHP.

Reklama
Reklama

Dlho som uvažoval, čo napíšem ako svoj prvý článok, no bolo mi jasné, že keďže mám veľa práce a málo voľna, nebudem robiť nijaké nové skripty, aby som vám ich predniesol. A vtedy sa ma pár ľudí spýtalo, ako sa robia smajlíci v pridávaní príspevkov do guest bookov, na blogy, fóra… Preto mi bolo jasné, že pár minút dnes venujem tejto malej problematike.

Mnoho začínajúcich s PHP sa diví nad systémami ako phpBB a obdivujú formátovanie textu pri pridávaní komentárov do fóra. A ak medzi nich patríte aj vy, tak vedzte, že je to neuveriteľne jednoduché. Prakticky ide len o nahradenie určitých vami zvolených znakov (napríklad na smajlíka), ktoré sa budú ukladať do databázy za HTML tagy.

Prvým krokom, ktorý je nutné urobiť, je vypracovanie formulára na vkladanie príspevkov (pravdaže textarea). Myslím, že ukazovať HTML formulár bude nanajvýš nepotrebné, pretože každý, kto PHP robí alebo s ním začína, sa mnoho ráz stretol s HTML. Preto prvý problém bude vloženie zvolených znakov do textarey po kliknutí na smajlíka. Táto krátka pasáž bude patriť JavaScriptu. Najprv si vo formulári určite pre textarea isté id a ku obrázkom smajlíkov dajte odkazy odkazujúce na javascriptovú funkciu s parametrami, napr.:

<textarea name="area" rows="20" cols="20" id="vloz"></textarea>
<a href="javascript:smajlik(':-)','vloz');"><img src=“smile1.gif“ alt=“:-)“></a>
<a href="javascript:smajlik(':-(','vloz');"><img src=“smile2.gif“ alt=“:-(“></a>
<a href="javascript:smajlik(':-D','vloz');"><img src=“smile3.gif“ alt=“:-D“></a>
<a href="javascript:smajlik(':-O','vloz');"><img src=“smile4.gif“ alt=“:-O“></a>

Funkcia (javascript) bude vyzerat asi takto:

function smajlik(kod,kde){
document.getElementById('kde').value+=kod
}

Vyplnené údaje formulára potom klasicky odošlete a uložíte do databázy známym:

MySQL_Query("INSERT INTO tabulka VALUES('','$meno','$area')");

Pravdaže podľa vzhľadu vašej tabuľky. Tá najdôležitejšia časť článku, o ktorej som tu vlastne chcel napísať príde pri výstupe stránky a vyťahovaní dát z databázy. Najprv zavoláme spojenie s databázou a načítame obsah bunky s textom z formulára do premennej obsah. Potom urobéme pár úprav textu (odstránime pridlhé slová – antispam, odstránime html znaky) a napokon si nadefinujeme dve polia najst a nahradit a potom nahradíme obsah jedného pola obsahom druhého pomocou PHP funkcie str_replace, tak si to pozrime:

$spojenie=mysql_connect(MySQL_server, MySQL_user, MySQL_user_password);
$spojeniedb=mysql_select_db(MySQL_db);
$hahaha = MySQL_Query("SELECT * FROM tabulka");
$hehehe = mysql_fetch_array($hahaha);
$obsah=$hehehe["obsah"];

$textik = wordwrap( $obsah, 50, "\n", 1); 
$texticek= htmlspecialchars($textik); 
$najst=array 
	(
	":-)",
	":-(",
	":-D",
	":-O",
	);

$nahradit=array
	(
	"<img src=\"smile1.gif\" alt=\":-)\" />", 
	"<img src=\"smile2.gif\" alt=\":-(\" />",
	"<img src=\"smile3.gif\" alt=\":-D" />",
	"<img src=\"smile4.gif\" alt=\":-O\" />",
	);

$text=str_replace($najst, $nahradit, $texticek); 

echo "$text"; 

Rovnaký účinok by bol aj vtedy, keby ste predchádzajúci skript použili aj pred uložením formulára do db a potom len tahali a pouzili echo, výber je len na vás. Skripty si môžete akokoľvek upraviť a možnosti javascriptu sú rôzne a dajú sa použiť aj iné funkcie.

S podobnými skriptami v praxi sa možno stretnúť pomerne často a kdekoľvek. Dúfam, že ak ste práve toto potrebovali nájsť, tak som vám pomohol. Podobné návody budem uverejnovať častejšie a takisto sa budem zaoberať v článkoch využitím a bezpečnosťou funkcií PHP

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
Autor programuje v PHP, MySQL a Javě.

Nové články

Reklama
Reklama
Obrázek ke článku Blockchain & Bitcoin konference

Blockchain & Bitcoin konference

V pátek 19. 5. 2017 se v pražském konferenčním centru Andel’s konala Blockchain & Bitcoin konference. Řada odborníků a podnikatelů v oboru blockchainu a kryptoměn představila možnosti budoucího směřování tohoto oboru. Speakeři většinou rusky mluvící provenience prezentovali řešení svých firem založená na technologii blockchainu.

Obrázek ke článku Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Bezpečnostní tým Cisco Talos odhalil celkem 4 kampaně dosud neobjeveného malwaru, který dostal jméno KONNI. Ten se dokázal úspěšně maskovat od roku 2014. Zpočátku se malware zaměřoval pouze na krádeže citlivých dat. Za 3 roky se ale několikrát vyvinul, přičemž jeho současná verze umožňuje útočníkovi z infikovaného počítače nejenom krást data, ale i mapovat stisky na klávesnici, pořizovat screenshoty obrazovky či v zařízení spustit libovolný kód. Pro odvedení pozornosti oběti zasílali útočníci v příloze také obrázek, zprávu a výhružkách severokorejského režimu či kontakty na členy mezinárodních organizací.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý