SlideShare una empresa de Scribd logo
1 de 29
Descargar para leer sin conexión
JavaScript în romgleză


Ștefan Petre
stefan.petre@gmail.com
Istorie


JavaScript
Netscape
Mocha       LiveScript       JavaScript   Netscape Navigator 2.0



Microsoft
JScript     Internet Explorer 3.0



Ecma International
ECMA-262        5 Ediții
Ce este                        Limbaj bazat pe funcții


JavaScript                     Funcțiile sunt obiecte
                               Loose typing
                               Prototypal inheritance
Este un LIMBAJ DE PROGRAMARE   Lambda
Ce nu este
             Nu are legatură cu Java
JavaScript   Nu se joacă doar în navigatoare
Librarii


JavaScript
Prototype        Toolkits

MooTools        YUI
Ender (jeesh)   Dojo
jQuery          Jquery UI
1.   Delegarea evenimentelor
1.      Delegarea evenimentelor
DIV#slideshow




              A.item   A.item   A.item   A.item




     A#left                                       A#right
1.   Delegarea evenimentelor


// funcția de procesare a click-ului
var clickHandler = function(ev) {
    var targetEl = $(ev.target).closest('a');
    if (targetEl.size() == 1) {
         if (targetEl[0].id == 'left') {
             // arată imaginile din stânga
         } else if (targetEl[0].id == 'right') {
             // arată imaginile din dreapta
         } else {
             // încarcă imaginea pe care s-a dat click
         }
    }
    return false;
};

// atașează 'clickHandler' evenimentului 'click' pe elementul parinte
$('#slideshow').bind('click', clickHandler);
2.   Accesarea propietăților

var divs = someParent.getElementsByTagName('DIV');
for ( var i = 0; i < divs.length; i++ ) {
    divs[i].style.color = '#f00';
    divs[i].style.fontWeight = 'bold';
    divs[i].style.fontStyle = 'italic';
}




Mai rapid
var divs = someParent.getElementsByTagName('DIV');
var stl;
for ( var i = 0, lng = divs.length; i < lng; i++ ) {
    stl = divs[i].style;
    stl.color = '#f00';
    stl.fontWeight = 'bold';
    stl.fontStyle = 'italic';
}
2.1   Cache valori

      1


      2
          3



      4


      5


      6
2.1   Cache valori

      1          var els = [];

                 var onMove = function() {
                     var currentPos = $(this).offset();
      2              var pos;
                     for (
          3               var i = 0, lng = els.length;
                          i < lng;
                          i ++
                     ) {
                          pos = $(els[i]).offset();
      4                   if (
                               pos.top > currentPos.top
                          ) {
      5                        // mută elmentul deasupra
                          }
                     }
                 };
      6
2.1   Cache valori

      1          Mai rapid
                 var els = [];
                 var parentPos = $(parent).offset();
      2
                 var onMove = function(ev) {
          3          var currentPos = $(this).offset();
                     for (
                          var i = 0, lng = els.length;
                          i < lng;
                          i ++
      4              ) {
                          if (
                               parentPos.top + els[i].offsetTop   >
                               currentPos.top
      5
                          ) {
                               // mută elmentul deasupra
                          }
      6              }
                 };
3.   Lazy functions

var bindEvent = function (el, evType, func) {
    if (window.addEventListener) {
         el.addEventListener(evType, func, false);
    } else if (window.attachEvent) {
         el.attachEvent('on' + evType, func, false);
    ]
}



Mai rapid și mai deștept
var bindEvent = function (el, evType, func) {
    if (window.addEventListener) {
         bindEvent = function (el, evType, func) {
             el.addEventListener(evType, func, false);
         }
    } else if (window.attachEvent) {
         bindEvent = function (el, evType, func) {
             el.attachEvent('on' + evType, func, false);
         }
    }
    bindEvent(el, evType, func);
}
4.   Touching the DOM

var divs = someParent.getElementsByTagName('DIV');
var stl;
for ( var i = 0, lng = divs.length; i < lng; i++ ) {
    stl = divs[i].style;
    stl.color = '#f00';
    stl.fontWeight = 'bold';
    stl.fontStyle = 'italic';
}


Mai rapid
var divs = document.getElementsByTagName('DIV');
for ( var i = 0, lng = divs.length; i < lng; i++ ) {
    divs[i].className = 'someClass';
}

.someClass {
    color: #f00;
    font-weight: bold;
    font-style: italic;
}
4.1   Fragmente ale documentului

var el;
for ( var i = 0; i < 100; i++ ) {
    el = document.createElement('p');
    el.innerHTML = 'Element: '+i;
    someParent.appendChild(el);
}



Mai rapid
var el;
var fragment = document.createDocumentFragment();
for ( var i = 0; i < 100; i++ ) {
    el = document.createElement('p');
    el.innerHTML = 'Element: '+i;
    fragment.appendChild(el);
}
someParent.appendChild(fragment);
4.2   innerHTML și concatenarea șirurilor


for ( var i = 0; i < 100; i++ ) {
    someParent.innerHTML += '<p>Element: '+i+'</p>';
}




Mai rapid
var html = [];
for ( var i = 0; i < 100; i++ ) {
    html[html.length] = '<p>Element: ';
    html[html.length] = i;
    html[html.length] = '</p>';
}
someParent.innerHTML += html.join('');
4.3   Modificarea definițiilor CSS
5.   Scroll virtual
5.   Scroll virtual
5.1   Scroll virtual
5.1   Scroll virtual
5.1   Scroll virtual
6.   Defer loading




function deferLoadJS() {
    var el = document.createElement("script");
     el.src = "app.js";
     document.body.appendChild(element);
}

bindEvent(window, 'load', deferLoadJS);
7.   setTimeout si clearTimeout
var winResizeObsv = function() {
     var timer;
     var regs = [];
     var announce = function() {
         for (var i=0, lng = regs.length; i < lng; i++) {
              regs[i].apply();
         }
     };
     return {
         register: function(callback) {
              regs.push(callback);
         },
         resize: function() {
              clearTimeout(timer);
              timer = setTimeout(announce, 200);
         }
     };
}();

$(window).bind('resize', winResizeObsv.resize);

winResizeObsv.register(mapContainer.resize);
winResizeObsv.register(optionsPanel.fixHeight);
7.1   Când se hotărăște utilizatorul
7.2   Mai bine mai târziu
7.2   Mai bine mai târziu
7.2   Mai bine mai târziu
Mulțumesc
ÎNTREBĂRI?

Más contenido relacionado

Destacado

Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Kurio // The Social Media Age(ncy)
 

Destacado (20)

Skeleton Culture Code
Skeleton Culture CodeSkeleton Culture Code
Skeleton Culture Code
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
 
How to have difficult conversations
How to have difficult conversations How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
 
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
Unlocking the Power of ChatGPT and AI in Testing - A Real-World Look, present...
 
12 Ways to Increase Your Influence at Work
12 Ways to Increase Your Influence at Work12 Ways to Increase Your Influence at Work
12 Ways to Increase Your Influence at Work
 
ChatGPT webinar slides
ChatGPT webinar slidesChatGPT webinar slides
ChatGPT webinar slides
 
More than Just Lines on a Map: Best Practices for U.S Bike Routes
More than Just Lines on a Map: Best Practices for U.S Bike RoutesMore than Just Lines on a Map: Best Practices for U.S Bike Routes
More than Just Lines on a Map: Best Practices for U.S Bike Routes
 
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
Ride the Storm: Navigating Through Unstable Periods / Katerina Rudko (Belka G...
 

JavaScript in romgleza

  • 1. JavaScript în romgleză Ștefan Petre stefan.petre@gmail.com
  • 2. Istorie JavaScript Netscape Mocha LiveScript JavaScript Netscape Navigator 2.0 Microsoft JScript Internet Explorer 3.0 Ecma International ECMA-262 5 Ediții
  • 3. Ce este Limbaj bazat pe funcții JavaScript Funcțiile sunt obiecte Loose typing Prototypal inheritance Este un LIMBAJ DE PROGRAMARE Lambda
  • 4. Ce nu este Nu are legatură cu Java JavaScript Nu se joacă doar în navigatoare
  • 5. Librarii JavaScript Prototype Toolkits MooTools YUI Ender (jeesh) Dojo jQuery Jquery UI
  • 6. 1. Delegarea evenimentelor
  • 7. 1. Delegarea evenimentelor DIV#slideshow A.item A.item A.item A.item A#left A#right
  • 8. 1. Delegarea evenimentelor // funcția de procesare a click-ului var clickHandler = function(ev) { var targetEl = $(ev.target).closest('a'); if (targetEl.size() == 1) { if (targetEl[0].id == 'left') { // arată imaginile din stânga } else if (targetEl[0].id == 'right') { // arată imaginile din dreapta } else { // încarcă imaginea pe care s-a dat click } } return false; }; // atașează 'clickHandler' evenimentului 'click' pe elementul parinte $('#slideshow').bind('click', clickHandler);
  • 9. 2. Accesarea propietăților var divs = someParent.getElementsByTagName('DIV'); for ( var i = 0; i < divs.length; i++ ) { divs[i].style.color = '#f00'; divs[i].style.fontWeight = 'bold'; divs[i].style.fontStyle = 'italic'; } Mai rapid var divs = someParent.getElementsByTagName('DIV'); var stl; for ( var i = 0, lng = divs.length; i < lng; i++ ) { stl = divs[i].style; stl.color = '#f00'; stl.fontWeight = 'bold'; stl.fontStyle = 'italic'; }
  • 10. 2.1 Cache valori 1 2 3 4 5 6
  • 11. 2.1 Cache valori 1 var els = []; var onMove = function() { var currentPos = $(this).offset(); 2 var pos; for ( 3 var i = 0, lng = els.length; i < lng; i ++ ) { pos = $(els[i]).offset(); 4 if ( pos.top > currentPos.top ) { 5 // mută elmentul deasupra } } }; 6
  • 12. 2.1 Cache valori 1 Mai rapid var els = []; var parentPos = $(parent).offset(); 2 var onMove = function(ev) { 3 var currentPos = $(this).offset(); for ( var i = 0, lng = els.length; i < lng; i ++ 4 ) { if ( parentPos.top + els[i].offsetTop > currentPos.top 5 ) { // mută elmentul deasupra } 6 } };
  • 13. 3. Lazy functions var bindEvent = function (el, evType, func) { if (window.addEventListener) { el.addEventListener(evType, func, false); } else if (window.attachEvent) { el.attachEvent('on' + evType, func, false); ] } Mai rapid și mai deștept var bindEvent = function (el, evType, func) { if (window.addEventListener) { bindEvent = function (el, evType, func) { el.addEventListener(evType, func, false); } } else if (window.attachEvent) { bindEvent = function (el, evType, func) { el.attachEvent('on' + evType, func, false); } } bindEvent(el, evType, func); }
  • 14. 4. Touching the DOM var divs = someParent.getElementsByTagName('DIV'); var stl; for ( var i = 0, lng = divs.length; i < lng; i++ ) { stl = divs[i].style; stl.color = '#f00'; stl.fontWeight = 'bold'; stl.fontStyle = 'italic'; } Mai rapid var divs = document.getElementsByTagName('DIV'); for ( var i = 0, lng = divs.length; i < lng; i++ ) { divs[i].className = 'someClass'; } .someClass { color: #f00; font-weight: bold; font-style: italic; }
  • 15. 4.1 Fragmente ale documentului var el; for ( var i = 0; i < 100; i++ ) { el = document.createElement('p'); el.innerHTML = 'Element: '+i; someParent.appendChild(el); } Mai rapid var el; var fragment = document.createDocumentFragment(); for ( var i = 0; i < 100; i++ ) { el = document.createElement('p'); el.innerHTML = 'Element: '+i; fragment.appendChild(el); } someParent.appendChild(fragment);
  • 16. 4.2 innerHTML și concatenarea șirurilor for ( var i = 0; i < 100; i++ ) { someParent.innerHTML += '<p>Element: '+i+'</p>'; } Mai rapid var html = []; for ( var i = 0; i < 100; i++ ) { html[html.length] = '<p>Element: '; html[html.length] = i; html[html.length] = '</p>'; } someParent.innerHTML += html.join('');
  • 17. 4.3 Modificarea definițiilor CSS
  • 18. 5. Scroll virtual
  • 19. 5. Scroll virtual
  • 20. 5.1 Scroll virtual
  • 21. 5.1 Scroll virtual
  • 22. 5.1 Scroll virtual
  • 23. 6. Defer loading function deferLoadJS() { var el = document.createElement("script"); el.src = "app.js"; document.body.appendChild(element); } bindEvent(window, 'load', deferLoadJS);
  • 24. 7. setTimeout si clearTimeout var winResizeObsv = function() { var timer; var regs = []; var announce = function() { for (var i=0, lng = regs.length; i < lng; i++) { regs[i].apply(); } }; return { register: function(callback) { regs.push(callback); }, resize: function() { clearTimeout(timer); timer = setTimeout(announce, 200); } }; }(); $(window).bind('resize', winResizeObsv.resize); winResizeObsv.register(mapContainer.resize); winResizeObsv.register(optionsPanel.fixHeight);
  • 25. 7.1 Când se hotărăște utilizatorul
  • 26. 7.2 Mai bine mai târziu
  • 27. 7.2 Mai bine mai târziu
  • 28. 7.2 Mai bine mai târziu