Curs Javascript

In acest tutorial este prezentat un script cu jQuery care evidentiaza in pagina cuvantul selectat prin dublu clic pe el.
Este util daca doriti sa adaugati in pagina dv. web posibilitatea ca atunci cand utilizatorul apasa dublu-click pe un cuvant din pagina, toate aparitiile acelui cuvand in pagina sa fie scoase in evidenta (colorate).
• Ca sa-l testati, apasati double-clic pe cuvinte din aceasta pagina.

- Acest script foloseste highlight plughin de la: www.johannburkard.de/blog/programming/javascript/highlight-javascript-text-higlighting-jquery-plugin.html .
- Explicatii despre cod sunt in comentariile din script.

Utilizare

1. Adaugati in pagina web (dupa libraria de functii jQuery) codul JavaScript de mai jos.
2. In CSS style adaugati acest cod (defineste culoarea si fundalul cuvantului selectat).
.highlight { background-color: yellow; color:blue; }
- Daca doriti sa fie scoase in evidenta doar cuvintele dintr-o anumita zona, inlocuiti "body" din linia de cod: $('body').dblclick(function(), cu referinta la acea zona. De exemplu: $('#id_element').dblclick(function() .

Codul Scriptului

<script type="text/javascript"><!--
/*
Plughin highlight v3
<http://johannburkard.de/blog/programming/javascript/highlight-javascript-text-higlighting-jquery-plugin.html>
Johann Burkard
<http://johannburkard.de>
*/
jQuery.fn.highlight = function(pat) {
 function innerHighlight(node, pat) {
  var skip = 0;
  if (node.nodeType == 3) {
   var pos = node.data.toUpperCase().indexOf(pat);
   if (pos >= 0) {
    var spannode = document.createElement('span');
    spannode.className = 'highlight';
    var middlebit = node.splitText(pos);
    var endbit = middlebit.splitText(pat.length);
    var middleclone = middlebit.cloneNode(true);
    spannode.appendChild(middleclone);
    middlebit.parentNode.replaceChild(spannode, middlebit);
    skip = 1;
   }
  }
  else if (node.nodeType == 1 && node.childNodes && !/(script|style)/i.test(node.tagName)) {
   for (var i = 0; i < node.childNodes.length; ++i) {
    i += innerHighlight(node.childNodes[i], pat);
   }
  }
  return skip;
 }
 return this.each(function() {
  innerHighlight(this, pat.toUpperCase());
 });
};
jQuery.fn.removeHighlight = function() {
 return this.find("span.highlight").each(function() {
  this.parentNode.firstChild.nodeName;
  with (this.parentNode) {
   replaceChild(this.firstChild, this);
   normalize();
  }
 }).end();
};

// aceasta functie preia textul selectat in pagina
function getSelText() {
  var seltxt = '';      // retine textul selectat

  // preia textul
  if (window.getSelection) {
    seltxt = window.getSelection();
  } else if (document.getSelection) {
    seltxt = document.getSelection();
  } else if (document.selection) {
    seltxt = document.selection.createRange().text;
  }
  return seltxt;
}
--></script>
<script type="text/javascript"><!--
$(document).ready(function() {
  // la dublu-clic pe un cuvant din cadrul BODY
  $('body').dblclick(function() {
    var seltxt = getSelText();      // preia cuvantul selectat
    seltxt = $.trim(seltxt);        // sterge spatiile din margine
    $(this).removeHighlight().highlight(seltxt);      // acceseaza functiile de anulare si evidentiere cuvant
  });
});
--></script>

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Care tag se foloseste in <table> pentru a crea celula de tip "header"?
<thead> <th> <td>
<table><tr>
  <th>Title 1</th>
  <th>Title 2</th>
</tr></table>
Ce proprietate CSS seteaza distanta dintre randuri?
line-height word-spacing margin
.some_class {
  line-height: 150%;
}
Care functie deschide o noua fereastra.
alert() confirm() open()
document.getElementById("id_button").onclick = function(){
  window.open("http://coursesweb.net/");
}
Indicati functia PHP care returneaza un array cu numele fisierelor si directoarelor dintr-un director.
mkdir() scandir() readdir()
$ar_dir = scandir("dir_name");
var_export($ar_dir);
Care din urmatoarele forme a verbului "sleep" (a dormi) se foloseste pentru viitor?
sleeping slept will sleep
He will sleep there.
- El va dormi acolo.
Care din urmatoarele forme a verbului "dormir" (a dormi) se foloseste pentru viitor?
dormido dormirá durmiendo
Él dormirá allí.
- El va dormi acolo.
Evidentiere cuvant selectat prin dublu-click

Last accessed pages

  1. Espanol Chistes - Glume, Bancuri (5046)
  2. I sau Me (8302)
  3. Download carti electronice si programe pentru Limba Engleza (43676)
  4. Substantivul din limba engleza - The Noun (59020)
  5. Ferestre Alert Prompt si Confirm (3200)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (695)
  2. Coduri pt culori (311)
  3. Exercitii engleza - English Tests and exercises - Grammar (306)
  4. Gramatica limbii engleze - Prezentare Generala (298)
  5. Cursuri limba engleza gratuite si lectii online (278)