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.
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