SlideShare a Scribd company logo
1 of 63
Download to read offline
JavaScript
  DOM Manipulations and Events

  Slides By: Ynon Perek

  Fine me at: http://ynonperek.com


Friday, April 12, 13
The Task
    Read text                                                                   Make web
   <BODY BGCOLOR='#FFFFFF' style="overflow:hidden;"
   LEFTMARGIN=0 MARGINWIDTH=0 TOPMARGIN=0
   MARGINHEIGHT=0 CLASS="text" onload="DisplayAD();"
   onresize="if(typeof DZresize == 'function'){DZresize();};if(typeof
   dcOnResize == 'function'){dcOnResize();};if(typeof
   disYnetAdColOnResize == 'function'){disYnetAdColOnResize();};"
   lang=he><div id='divRedAlert' style='display:none;'></div><iframe
   id=frmRedAlert name=frmRedAlert frameborder=0 width=0 height=0
   MARGINHEIGHT=0 MARGINWIDTH=0 src='/Ext/App/RedAlert/
   CdaRedAlert_iframe/0,12639,84-234-208-20,00.html'></iframe><div
   id='ads.ozen' style='position:absolute;z-index:2;left:0;top:0;'></div><div
   id='ads.elvisR.1' style='position:absolute;z-index:2;right:0;top:0;'></
   div><div id=mainCont style="overflow:hidden; width:100%; height:100%;"
   align=center ><div id='mainSpacer' style='overflow:auto;height:
   100%'><script>
   <style>A.brightgrey:link{color:#7d7f7e}
   A.brightgrey:visited{color:#7d7f7e}A.brightgrey:active{color:#7d7f7e}
   A.brightgrey:hover{color:#f00}A.upnvl{color:#7d7f80}
   A.upnvl:visited{color:#7d7f80}A.upnvl:hover{color:#f00}
   A.btnvl{color:#7f90b0}A.btnvl:visited{color:#7f90b0}
   A.btnvl:hover{color:#f00}</style><table id=tbl_logos cellspacing=0 cetd
   width='46' align='left' style='line-height:12px;'><a href='http://
   www.ynetnews.com/home/0,7340,L-3083,00.html' class='text11
   btnvl'>English</a></td></tr></table></div></td><td width=11>&nbsp;</
   td><td width=2 bgcolor=black></td><td width=11>&nbsp;</td><td
   width=132 valign=top style='direction: rtl;' class='ghci3' ><div
   id=divMainLogo style='margin-top:1px;'></div></td><td width=11><div
   style='width:11px;'></div></td><TD WIDTH=194 align=right dir=rtl
   VALIGN=top class='ghciTopStoryMain1' ><div dir=ltr style='height:
   38px;overflow:hidden;'><IMG SRC='/Common/Files/Images/Date/12.gif'
   alt="12/04/2013 11:20"><IMG SRC='/Common/Files/Images/D...




Friday, April 12, 13
How Browsers Render


                       • Each browser has a Rendering Engine
                       • Rendering Engine takes an HTML text
                         and produces a DOM tree




Friday, April 12, 13
Rendering Engines
     Engine                Browser           Developer


     Blink                 Google Chrome     Google


     Gecko                 Mozilla Firefox   Mozilla


     Trident               IE                Microsoft

                                             Apple, KDE, Nokia,
     Webkit                Apple Safari
                                             Others



Friday, April 12, 13
How Browsers Work
                        Parse HTML to make DOM Tree


                         Build Render Tree from CSS


                              Layout Elements


                                   Paint

Friday, April 12, 13
What’s a DOM Tree

    <html>
    <body>
      <p>
                       Hello World
      </p>
      <div>
       <img src="example.png"/>
      </div>
    </body>
    </html>




Friday, April 12, 13
Rendering DOM Tree




Friday, April 12, 13
Rendering DOM Tree


                       • A Render tree is derived from DOM
                         tree
                       • It’s not a 1-1 relation




Friday, April 12, 13
Browser Flow

                       • Read page as text
                       • Create DOM tree
                       • Create Render tree
                       • Paint



Friday, April 12, 13
Enter JavaScript

                       • Read page as text
                       • Create DOM tree        JavaScript
                                              Manipulates the
                       • Create Render tree
                                                   data
                       • Paint



Friday, April 12, 13
Enter JavaScript

                       • JavaScript alters page load

                       • JavaScript alters DOM Tree
                       • JavaScript creates interactivity through
                         events handling




Friday, April 12, 13
JavaScript and DOM
   <!DOCTYPE html>
   <html>
   <head>
     <title></title>
   </head>
   <body>                  A <script> element is
     <script>
       var x = 5;          executed in place
       var y = 3;
       console.log('Hello From JS');
     </script>
     <p>This is just some text</p>
   </body>
   </html>




Friday, April 12, 13
Q&A
         Browser Page Rendering




Friday, April 12, 13
Interactive Apps


                       • Browser is a programming platform
                       • A web application is interactive




Friday, April 12, 13
Interactivity


                       • Browser itself is interactive
                       • In addition: A web page is interactive
                       • Demo




Friday, April 12, 13
Browser Events Loop

                                  Event Queue

                                                click




Friday, April 12, 13
Event Loop

                        Wait for Events




                        Handle Events



Friday, April 12, 13
Event Loop

                        Wait for Events




                        Handle Events



Friday, April 12, 13
Event Loop

                        Wait for Events




                        Handle Events



Friday, April 12, 13
Event Handling

                       DOM Node

                          +           Event Handler (code)

                         Event



Friday, April 12, 13
Code Outline


                       • From HTML:
                        • <a on...=”handleEvent()”>




Friday, April 12, 13
Code Outline
                       • But this can get messy
                         <a href="#" onclick="doclick"
                             onblur="doblur"
                             onchange="dochange"
                             ondblclick="dodblclick"
                             onmousemove="domove"
                             onmouseover="doover">
                         Too many events</a>



Friday, April 12, 13
Code Outline


                       • From JS
                        • Get a DOM node
                        • Bind event to code




Friday, April 12, 13
Getting DOM Nodes


                       • getElementById(...)
                       • getElementsByTagName(...)
                       • querySelector(...) - IE8 and up




Friday, April 12, 13
Browser Events

                       • All browsers use:
                         node.onevent = ...
                       • IE uses:
                         node.attachEvent(...)
                       • Other browsers use
                         node.addEventListener(...)


Friday, April 12, 13
Demo: Events


                       • Write a simple page that shows alert as
                         a response to click event
                       • Modify to change text of element




Friday, April 12, 13
Using the Event Object
                       • Event object includes info on the event
                       • Print it to console for inspection

                <button>Click Me</button>
           
                <script>
                  var btn = document.getElementsByTagName('button')[0];
                  btn.onclick = function(e) {
                    if ( ! e ) e = window.event;
           
                    console.dir( e );
                  };
                </script>


Friday, April 12, 13
Capturing vs. Bubbling

                      | |                                   / 
       ---------------| |-----------------   ---------------| |-----------------
       | element1     | |                |   | element1     | |                |
       |   -----------| |-----------     |   |   -----------| |-----------     |
       |   |element2  /           |     |   |   |element2 | |           |     |
       |   -------------------------     |   |   -------------------------     |
       |        Event CAPTURING          |   |        Event BUBBLING           |
       -----------------------------------   -----------------------------------




Friday, April 12, 13
Capturing vs. Bubbling

                      | |                                   / 
       ---------------| |-----------------   ---------------| |-----------------
       | element1     | |                |   | element1     | |                |
       |   -----------| |-----------     |   |   -----------| |-----------     |
       |   |element2  /           |     |   |   |element2 | |           |     |
       |   -------------------------     |   |   -------------------------     |
       |        Event CAPTURING          |   |        Event BUBBLING           |
       -----------------------------------   -----------------------------------


         Netscape                             Microsoft




Friday, April 12, 13
Capturing vs. Bubbling

                                        | | / 
                       -----------------| |--| |-----------------
                       | element1       | | | |                 |
                       |   -------------| |--| |-----------     |
                       |   |element2     / | |           |     |
                       |   --------------------------------     |
                       |        W3C event model                 |
                       ------------------------------------------




Friday, April 12, 13
Capturing vs. Bubbling

                       • node.addEventListener takes a third
                         parameter
                       • true means capturing
                       • false means bubbling
                       • defaults to false



Friday, April 12, 13
Demo


                       • Capture all click events using
                         document.onclick = ...




Friday, April 12, 13
Usages


                       • Default event handlers
                       • Dynamic event handlers




Friday, April 12, 13
Double Handlers

                                  element1.onclick =
                       Element2   doSomething;
                       Element1   element2.onclick =
                                  doSomething;




Friday, April 12, 13
Double Handlers
                                  function   doSomething(e) {
                                        if   ( ! e ) e = window.event;
                       Element2    
                                        //   this refers to
                       Element1         //   the current element

                                        // for inner event:
                                        // this = element2

                                        // for outer event:
                                        // this = element1
                                  }




Friday, April 12, 13
Event Types
             Interface Events            Mouse Events       Form Events



                  load, unload            click, dblclick     submit


                                      mousedown, mouseup,
                  resize, scroll,                              reset
                                          mousemove


                       focus, blur    mouseover, mouseout


Friday, April 12, 13
Default Action

                       • Some events also have a “default”
                         action
                       • For example: A link will take you to
                         another page by default




Friday, April 12, 13
Default Action


                       • Possible to prevent
                       • return false from handler
                       • Demo




Friday, April 12, 13
Q&A
         Handling Events




Friday, April 12, 13
Events Lab

                       • Implement 5 duplicated input boxes
                       • Each input box should have the same
                         text
                       • Change one -> all change automatically




Friday, April 12, 13
Events Lab




Friday, April 12, 13
Altering Page Load


                       • Change Document
                       • Change DOM Tree
                       • Change Render Tree




Friday, April 12, 13
Change Document


                       • (Don’t) use document.write to change
                         the document as it’s being loaded
                       • Considered bad practice




Friday, April 12, 13
Change Document
    <!DOCTYPE html>
    <html>
    <head>
      <title></title>
    </head>
    <body>
      <script>
        document.write('<h1>Hello World</h1>');
      </script>
      <p>This is just some text</p>
    </body>
    </html>




Friday, April 12, 13
Change Document
      1. Browser starts to
      create DOM tree

                                 body


                                2. Finds a script tag.
                       script   Stops to execute


Friday, April 12, 13
Change Document

                                body


                                       3. script added <h1>
                       script    h1    element to document




Friday, April 12, 13
Change Document

                                body



                       script     h1      p


                4. browser can continue
                to create the <p>

Friday, April 12, 13
Avoiding document.write


                       • Can insert invalid content
                       • Clobbers DOM if called after reading
                         the document




Friday, April 12, 13
Friendlier Ways


                       • Get a DOM node
                       • Change it using DOM API




Friday, April 12, 13
Finding
         DOM
         Nodes


Friday, April 12, 13
DOM Traversal
  <body>                                    body
    <div>
      <h1>Header</h1>
      <p>
        <img src="..." />       #text       #div       #text
        Paragraph text
        <a
  href="#">google</a>       #text   #text    #h1   #text       #p
      </p>
    </div>
  </body>




Friday, April 12, 13
DOM Traversal
                       • n.childNodes[]
                       • n.firstChild
                       • n.lastChild
                       • n.nextSibling
                       • n.parentNode
                       • n.previousSibling


Friday, April 12, 13
The (Past) Future


                       • document.querySelector takes any CSS
                         selector and fetches DOM element
                       • Supported in IE8 and later




Friday, April 12, 13
DOM API

                       • Allows
                        • Getting info on elements
                        • Changing element attributes
                        • Creating new elements
                        • Setting elements style


Friday, April 12, 13
DOM API
                       • Use x.nodeName to get the tag name

                       if ( this.nodeName === 'INPUT' ){
                         // handle input element
                       }




Friday, April 12, 13
DOM API

                       • Use x.nodeValue to get/set the node
                         value

              a.firstChild.nodeValue = 'Go to google';




Friday, April 12, 13
DOM API
                       • Use getAttribute / setAttribute to
                         change element attributes


           a.setAttribute('href',
                          'http://www.google.com');




Friday, April 12, 13
Creating New Elements
                       • Create elements and text nodes using
                         document
                       • Later you can add them to the DOM

                        document.createElement('P');

                        document.createTextNode('Hello
                        World');



Friday, April 12, 13
Creating New Elements
                       • Insert new nodes by manipulating
                         existing
                        // append y to x
                        x.appendChild(y)
                         
                        // insert y to x before z
                        x.insertBefore(y,z)
                         
                        // remove y from x
                        x.removeChild(y)
                         
                        // replace y with z
                        x.replaceChild(y,z)


Friday, April 12, 13
Change Style
                       • Use .style property to set an element
                         style
                       • Note style keys are almost like CSS
                         property names

                        p.style.backgroundColor = 'blue';




Friday, April 12, 13
Q&A
         Handling Events




Friday, April 12, 13
DOM Lab
                       • Given the HTML at:
                         http://jsbin.com/ecitag/1/edit
                       • Use JavaScript to:
                        • write your name in the first <li> item
                          of the second list
                        • Change the H3 to H4
                        • Set all links to point to google.com

Friday, April 12, 13
DOM Lab


                       • Create a Money Converter calculator
                       • Support 3 currencies




Friday, April 12, 13

More Related Content

What's hot

Web Performance Tips
Web Performance TipsWeb Performance Tips
Web Performance TipsRavi Raj
 
Javascript inside Browser (DOM)
Javascript inside Browser (DOM)Javascript inside Browser (DOM)
Javascript inside Browser (DOM)Vlad Mysla
 
Angular - Chapter 4 - Data and Event Handling
 Angular - Chapter 4 - Data and Event Handling Angular - Chapter 4 - Data and Event Handling
Angular - Chapter 4 - Data and Event HandlingWebStackAcademy
 
Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2borkweb
 
jQuery -Chapter 2 - Selectors and Events
jQuery -Chapter 2 - Selectors and Events jQuery -Chapter 2 - Selectors and Events
jQuery -Chapter 2 - Selectors and Events WebStackAcademy
 
Frontend Engineer Toolbox
Frontend Engineer ToolboxFrontend Engineer Toolbox
Frontend Engineer ToolboxYnon Perek
 
jQuery - Chapter 1 - Introduction
 jQuery - Chapter 1 - Introduction jQuery - Chapter 1 - Introduction
jQuery - Chapter 1 - IntroductionWebStackAcademy
 
KMUTNB - Internet Programming 4/7
KMUTNB - Internet Programming 4/7KMUTNB - Internet Programming 4/7
KMUTNB - Internet Programming 4/7phuphax
 
AJAX Workshop Notes
AJAX Workshop NotesAJAX Workshop Notes
AJAX Workshop NotesPamela Fox
 
jQuery introduction
jQuery introductionjQuery introduction
jQuery introductionTomi Juhola
 
jQuery - Chapter 3 - Effects
jQuery - Chapter 3 - Effects  jQuery - Chapter 3 - Effects
jQuery - Chapter 3 - Effects WebStackAcademy
 
Angular - Chapter 7 - HTTP Services
Angular - Chapter 7 - HTTP ServicesAngular - Chapter 7 - HTTP Services
Angular - Chapter 7 - HTTP ServicesWebStackAcademy
 
Introduction to Prototype JS Framework
Introduction to Prototype JS FrameworkIntroduction to Prototype JS Framework
Introduction to Prototype JS FrameworkMohd Imran
 
Internet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web Technology
Internet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web TechnologyInternet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web Technology
Internet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web TechnologyAyes Chinmay
 

What's hot (20)

Web Performance Tips
Web Performance TipsWeb Performance Tips
Web Performance Tips
 
Javascript inside Browser (DOM)
Javascript inside Browser (DOM)Javascript inside Browser (DOM)
Javascript inside Browser (DOM)
 
Scripting The Dom
Scripting The DomScripting The Dom
Scripting The Dom
 
Angular - Chapter 4 - Data and Event Handling
 Angular - Chapter 4 - Data and Event Handling Angular - Chapter 4 - Data and Event Handling
Angular - Chapter 4 - Data and Event Handling
 
Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2
 
jQuery -Chapter 2 - Selectors and Events
jQuery -Chapter 2 - Selectors and Events jQuery -Chapter 2 - Selectors and Events
jQuery -Chapter 2 - Selectors and Events
 
Frontend Engineer Toolbox
Frontend Engineer ToolboxFrontend Engineer Toolbox
Frontend Engineer Toolbox
 
jQuery - Chapter 1 - Introduction
 jQuery - Chapter 1 - Introduction jQuery - Chapter 1 - Introduction
jQuery - Chapter 1 - Introduction
 
KMUTNB - Internet Programming 4/7
KMUTNB - Internet Programming 4/7KMUTNB - Internet Programming 4/7
KMUTNB - Internet Programming 4/7
 
Java script
Java scriptJava script
Java script
 
lect9
lect9lect9
lect9
 
AJAX Workshop Notes
AJAX Workshop NotesAJAX Workshop Notes
AJAX Workshop Notes
 
jQuery introduction
jQuery introductionjQuery introduction
jQuery introduction
 
Web Components
Web ComponentsWeb Components
Web Components
 
jQuery - Chapter 3 - Effects
jQuery - Chapter 3 - Effects  jQuery - Chapter 3 - Effects
jQuery - Chapter 3 - Effects
 
Knockout.js
Knockout.jsKnockout.js
Knockout.js
 
Introduction to java_script
Introduction to java_scriptIntroduction to java_script
Introduction to java_script
 
Angular - Chapter 7 - HTTP Services
Angular - Chapter 7 - HTTP ServicesAngular - Chapter 7 - HTTP Services
Angular - Chapter 7 - HTTP Services
 
Introduction to Prototype JS Framework
Introduction to Prototype JS FrameworkIntroduction to Prototype JS Framework
Introduction to Prototype JS Framework
 
Internet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web Technology
Internet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web TechnologyInternet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web Technology
Internet and Web Technology (CLASS-9) [React.js] | NIC/NIELIT Web Technology
 

Viewers also liked

Scalable JavaScript
Scalable JavaScriptScalable JavaScript
Scalable JavaScriptYnon Perek
 
Dom selecting & jQuery
Dom selecting & jQueryDom selecting & jQuery
Dom selecting & jQueryKim Hunmin
 
03 Advanced JavaScript
03 Advanced JavaScript03 Advanced JavaScript
03 Advanced JavaScriptYnon Perek
 
02 JavaScript Syntax
02 JavaScript Syntax02 JavaScript Syntax
02 JavaScript SyntaxYnon Perek
 
DOM Features You Didn’t Know Existed
DOM Features You Didn’t Know ExistedDOM Features You Didn’t Know Existed
DOM Features You Didn’t Know ExistedFITC
 
Working with Arrays in JavaScript
Working with Arrays in JavaScriptWorking with Arrays in JavaScript
Working with Arrays in JavaScriptFlorence Davis
 
Javascript basics
Javascript basicsJavascript basics
Javascript basicsSolv AS
 
Javascript - Array - Writing
Javascript - Array - WritingJavascript - Array - Writing
Javascript - Array - WritingSamuel Santos
 
MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...
MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...
MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...Valeri Karpov
 
Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)
Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)
Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)Shreeraj Shah
 
AngularJS for designers and developers
AngularJS for designers and developersAngularJS for designers and developers
AngularJS for designers and developersKai Koenig
 
Dom API In Java Script
Dom API In Java ScriptDom API In Java Script
Dom API In Java ScriptRajat Pandit
 
Writing Reusable Web Components with jQuery and jQuery UI
Writing Reusable Web Components with jQuery and jQuery UIWriting Reusable Web Components with jQuery and jQuery UI
Writing Reusable Web Components with jQuery and jQuery UIYnon Perek
 

Viewers also liked (20)

Angularjs Basics
Angularjs BasicsAngularjs Basics
Angularjs Basics
 
Scalable JavaScript
Scalable JavaScriptScalable JavaScript
Scalable JavaScript
 
Dom selecting & jQuery
Dom selecting & jQueryDom selecting & jQuery
Dom selecting & jQuery
 
03 Advanced JavaScript
03 Advanced JavaScript03 Advanced JavaScript
03 Advanced JavaScript
 
02 JavaScript Syntax
02 JavaScript Syntax02 JavaScript Syntax
02 JavaScript Syntax
 
Introduction to the DOM
Introduction to the DOMIntroduction to the DOM
Introduction to the DOM
 
DOM Features You Didn’t Know Existed
DOM Features You Didn’t Know ExistedDOM Features You Didn’t Know Existed
DOM Features You Didn’t Know Existed
 
Working with Arrays in JavaScript
Working with Arrays in JavaScriptWorking with Arrays in JavaScript
Working with Arrays in JavaScript
 
Javascript basics
Javascript basicsJavascript basics
Javascript basics
 
Intro to SVGs
Intro to SVGsIntro to SVGs
Intro to SVGs
 
Javascript - Array - Writing
Javascript - Array - WritingJavascript - Array - Writing
Javascript - Array - Writing
 
MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...
MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...
MEAN Stack NYC Meetup 20150717: TDD Your AngularJS + Ionic Directives With jQ...
 
Css2
Css2Css2
Css2
 
Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)
Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)
Next Generation Web Attacks – HTML 5, DOM(L3) and XHR(L2)
 
AngularJS for designers and developers
AngularJS for designers and developersAngularJS for designers and developers
AngularJS for designers and developers
 
Html5 apis
Html5 apisHtml5 apis
Html5 apis
 
Arrays
ArraysArrays
Arrays
 
Dom API In Java Script
Dom API In Java ScriptDom API In Java Script
Dom API In Java Script
 
Writing Reusable Web Components with jQuery and jQuery UI
Writing Reusable Web Components with jQuery and jQuery UIWriting Reusable Web Components with jQuery and jQuery UI
Writing Reusable Web Components with jQuery and jQuery UI
 
Performance
PerformancePerformance
Performance
 

Similar to JavaScript DOM Manipulations

Building Your First Store App with XAML and C#
Building Your First Store App with XAML and C#Building Your First Store App with XAML and C#
Building Your First Store App with XAML and C#Tamir Dresher
 
Bundling Client Side Assets
Bundling Client Side AssetsBundling Client Side Assets
Bundling Client Side AssetsTimothy Oxley
 
Integrate Spring MVC with RequireJS & Backbone.js & Spring Data JPA
Integrate Spring MVC with RequireJS & Backbone.js & Spring Data JPAIntegrate Spring MVC with RequireJS & Backbone.js & Spring Data JPA
Integrate Spring MVC with RequireJS & Backbone.js & Spring Data JPACheng Ta Yeh
 
Speeding up mobile web apps
Speeding up mobile web appsSpeeding up mobile web apps
Speeding up mobile web appsIvano Malavolta
 
component: ruby gems for the browser
component: ruby gems for the browsercomponent: ruby gems for the browser
component: ruby gems for the browserTimothy Oxley
 
MongoTalk/Voyage
MongoTalk/VoyageMongoTalk/Voyage
MongoTalk/VoyageESUG
 
Building with JavaScript - write less by using the right tools
Building with JavaScript -  write less by using the right toolsBuilding with JavaScript -  write less by using the right tools
Building with JavaScript - write less by using the right toolsChristian Heilmann
 
Custom Android Code Templates
Custom Android Code TemplatesCustom Android Code Templates
Custom Android Code Templatesmurphonic
 
Fast Cordova applications
Fast Cordova applicationsFast Cordova applications
Fast Cordova applicationsIvano Malavolta
 
XPages Blast - Lotusphere 2013
XPages Blast - Lotusphere 2013XPages Blast - Lotusphere 2013
XPages Blast - Lotusphere 2013Tim Clark
 
Writing JavaScript that doesn't suck
Writing JavaScript that doesn't suckWriting JavaScript that doesn't suck
Writing JavaScript that doesn't suckRoss Bruniges
 
Jazz up your JavaScript: Unobtrusive scripting with JavaScript libraries
Jazz up your JavaScript: Unobtrusive scripting with JavaScript librariesJazz up your JavaScript: Unobtrusive scripting with JavaScript libraries
Jazz up your JavaScript: Unobtrusive scripting with JavaScript librariesSimon Willison
 
XPages Blast - Lotusphere 2012
XPages Blast - Lotusphere 2012XPages Blast - Lotusphere 2012
XPages Blast - Lotusphere 2012Tim Clark
 
Tek 2013 - Building Web Apps from a New Angle with AngularJS
Tek 2013 - Building Web Apps from a New Angle with AngularJSTek 2013 - Building Web Apps from a New Angle with AngularJS
Tek 2013 - Building Web Apps from a New Angle with AngularJSPablo Godel
 
Augmented Reality with JavaScript and Appcelerator Titanium
Augmented Reality with JavaScript and Appcelerator TitaniumAugmented Reality with JavaScript and Appcelerator Titanium
Augmented Reality with JavaScript and Appcelerator TitaniumJeff Bonnes
 
Performance & Responsive Web Design
Performance & Responsive Web DesignPerformance & Responsive Web Design
Performance & Responsive Web DesignZach Leatherman
 
Document Object Model
Document Object ModelDocument Object Model
Document Object Modelchomas kandar
 
Document Object Model
Document Object ModelDocument Object Model
Document Object Modelchomas kandar
 

Similar to JavaScript DOM Manipulations (20)

Fork cli tool
Fork cli toolFork cli tool
Fork cli tool
 
Building Your First Store App with XAML and C#
Building Your First Store App with XAML and C#Building Your First Store App with XAML and C#
Building Your First Store App with XAML and C#
 
Fast mobile web apps
Fast mobile web appsFast mobile web apps
Fast mobile web apps
 
Bundling Client Side Assets
Bundling Client Side AssetsBundling Client Side Assets
Bundling Client Side Assets
 
Integrate Spring MVC with RequireJS & Backbone.js & Spring Data JPA
Integrate Spring MVC with RequireJS & Backbone.js & Spring Data JPAIntegrate Spring MVC with RequireJS & Backbone.js & Spring Data JPA
Integrate Spring MVC with RequireJS & Backbone.js & Spring Data JPA
 
Speeding up mobile web apps
Speeding up mobile web appsSpeeding up mobile web apps
Speeding up mobile web apps
 
component: ruby gems for the browser
component: ruby gems for the browsercomponent: ruby gems for the browser
component: ruby gems for the browser
 
MongoTalk/Voyage
MongoTalk/VoyageMongoTalk/Voyage
MongoTalk/Voyage
 
Building with JavaScript - write less by using the right tools
Building with JavaScript -  write less by using the right toolsBuilding with JavaScript -  write less by using the right tools
Building with JavaScript - write less by using the right tools
 
Custom Android Code Templates
Custom Android Code TemplatesCustom Android Code Templates
Custom Android Code Templates
 
Fast Cordova applications
Fast Cordova applicationsFast Cordova applications
Fast Cordova applications
 
XPages Blast - Lotusphere 2013
XPages Blast - Lotusphere 2013XPages Blast - Lotusphere 2013
XPages Blast - Lotusphere 2013
 
Writing JavaScript that doesn't suck
Writing JavaScript that doesn't suckWriting JavaScript that doesn't suck
Writing JavaScript that doesn't suck
 
Jazz up your JavaScript: Unobtrusive scripting with JavaScript libraries
Jazz up your JavaScript: Unobtrusive scripting with JavaScript librariesJazz up your JavaScript: Unobtrusive scripting with JavaScript libraries
Jazz up your JavaScript: Unobtrusive scripting with JavaScript libraries
 
XPages Blast - Lotusphere 2012
XPages Blast - Lotusphere 2012XPages Blast - Lotusphere 2012
XPages Blast - Lotusphere 2012
 
Tek 2013 - Building Web Apps from a New Angle with AngularJS
Tek 2013 - Building Web Apps from a New Angle with AngularJSTek 2013 - Building Web Apps from a New Angle with AngularJS
Tek 2013 - Building Web Apps from a New Angle with AngularJS
 
Augmented Reality with JavaScript and Appcelerator Titanium
Augmented Reality with JavaScript and Appcelerator TitaniumAugmented Reality with JavaScript and Appcelerator Titanium
Augmented Reality with JavaScript and Appcelerator Titanium
 
Performance & Responsive Web Design
Performance & Responsive Web DesignPerformance & Responsive Web Design
Performance & Responsive Web Design
 
Document Object Model
Document Object ModelDocument Object Model
Document Object Model
 
Document Object Model
Document Object ModelDocument Object Model
Document Object Model
 

More from Ynon Perek

09 performance
09 performance09 performance
09 performanceYnon Perek
 
Mobile Web Intro
Mobile Web IntroMobile Web Intro
Mobile Web IntroYnon Perek
 
Qt multi threads
Qt multi threadsQt multi threads
Qt multi threadsYnon Perek
 
Mobile Devices
Mobile DevicesMobile Devices
Mobile DevicesYnon Perek
 
Architecture app
Architecture appArchitecture app
Architecture appYnon Perek
 
Unit Testing JavaScript Applications
Unit Testing JavaScript ApplicationsUnit Testing JavaScript Applications
Unit Testing JavaScript ApplicationsYnon Perek
 
How to write easy-to-test JavaScript
How to write easy-to-test JavaScriptHow to write easy-to-test JavaScript
How to write easy-to-test JavaScriptYnon Perek
 
Introduction to Selenium and Ruby
Introduction to Selenium and RubyIntroduction to Selenium and Ruby
Introduction to Selenium and RubyYnon Perek
 
Introduction To Web Application Testing
Introduction To Web Application TestingIntroduction To Web Application Testing
Introduction To Web Application TestingYnon Perek
 
Qt Design Patterns
Qt Design PatternsQt Design Patterns
Qt Design PatternsYnon Perek
 
Web Application Security
Web Application SecurityWeb Application Security
Web Application SecurityYnon Perek
 

More from Ynon Perek (20)

Regexp
RegexpRegexp
Regexp
 
Html5 intro
Html5 introHtml5 intro
Html5 intro
 
09 performance
09 performance09 performance
09 performance
 
Mobile Web Intro
Mobile Web IntroMobile Web Intro
Mobile Web Intro
 
Qt multi threads
Qt multi threadsQt multi threads
Qt multi threads
 
Vimperl
VimperlVimperl
Vimperl
 
Syllabus
SyllabusSyllabus
Syllabus
 
Mobile Devices
Mobile DevicesMobile Devices
Mobile Devices
 
Network
NetworkNetwork
Network
 
Architecture app
Architecture appArchitecture app
Architecture app
 
Cryptography
CryptographyCryptography
Cryptography
 
Unit Testing JavaScript Applications
Unit Testing JavaScript ApplicationsUnit Testing JavaScript Applications
Unit Testing JavaScript Applications
 
How to write easy-to-test JavaScript
How to write easy-to-test JavaScriptHow to write easy-to-test JavaScript
How to write easy-to-test JavaScript
 
Introduction to Selenium and Ruby
Introduction to Selenium and RubyIntroduction to Selenium and Ruby
Introduction to Selenium and Ruby
 
Introduction To Web Application Testing
Introduction To Web Application TestingIntroduction To Web Application Testing
Introduction To Web Application Testing
 
Accessibility
AccessibilityAccessibility
Accessibility
 
Angularjs
AngularjsAngularjs
Angularjs
 
Js memory
Js memoryJs memory
Js memory
 
Qt Design Patterns
Qt Design PatternsQt Design Patterns
Qt Design Patterns
 
Web Application Security
Web Application SecurityWeb Application Security
Web Application Security
 

Recently uploaded

SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024Scott Keck-Warren
 
Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...Alan Dix
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonetsnaman860154
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksSoftradix Technologies
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking MenDelhi Call girls
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesSinan KOZAK
 
Artificial intelligence in the post-deep learning era
Artificial intelligence in the post-deep learning eraArtificial intelligence in the post-deep learning era
Artificial intelligence in the post-deep learning eraDeakin University
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024BookNet Canada
 
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024BookNet Canada
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxMalak Abu Hammad
 
AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsMemoori
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreternaman860154
 
CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):comworks
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Patryk Bandurski
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsEnterprise Knowledge
 
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationBeyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationSafe Software
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitecturePixlogix Infotech
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...HostedbyConfluent
 

Recently uploaded (20)

SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024
 
Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...Swan(sea) Song – personal research during my six years at Swansea ... and bey...
Swan(sea) Song – personal research during my six years at Swansea ... and bey...
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
 
Benefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other FrameworksBenefits Of Flutter Compared To Other Frameworks
Benefits Of Flutter Compared To Other Frameworks
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
 
Vulnerability_Management_GRC_by Sohang Sengupta.pptx
Vulnerability_Management_GRC_by Sohang Sengupta.pptxVulnerability_Management_GRC_by Sohang Sengupta.pptx
Vulnerability_Management_GRC_by Sohang Sengupta.pptx
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen Frames
 
Artificial intelligence in the post-deep learning era
Artificial intelligence in the post-deep learning eraArtificial intelligence in the post-deep learning era
Artificial intelligence in the post-deep learning era
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
 
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptx
 
AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial Buildings
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
 
CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
 
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationBeyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC Architecture
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
 

JavaScript DOM Manipulations

  • 1. JavaScript DOM Manipulations and Events Slides By: Ynon Perek Fine me at: http://ynonperek.com Friday, April 12, 13
  • 2. The Task Read text Make web <BODY BGCOLOR='#FFFFFF' style="overflow:hidden;" LEFTMARGIN=0 MARGINWIDTH=0 TOPMARGIN=0 MARGINHEIGHT=0 CLASS="text" onload="DisplayAD();" onresize="if(typeof DZresize == 'function'){DZresize();};if(typeof dcOnResize == 'function'){dcOnResize();};if(typeof disYnetAdColOnResize == 'function'){disYnetAdColOnResize();};" lang=he><div id='divRedAlert' style='display:none;'></div><iframe id=frmRedAlert name=frmRedAlert frameborder=0 width=0 height=0 MARGINHEIGHT=0 MARGINWIDTH=0 src='/Ext/App/RedAlert/ CdaRedAlert_iframe/0,12639,84-234-208-20,00.html'></iframe><div id='ads.ozen' style='position:absolute;z-index:2;left:0;top:0;'></div><div id='ads.elvisR.1' style='position:absolute;z-index:2;right:0;top:0;'></ div><div id=mainCont style="overflow:hidden; width:100%; height:100%;" align=center ><div id='mainSpacer' style='overflow:auto;height: 100%'><script> <style>A.brightgrey:link{color:#7d7f7e} A.brightgrey:visited{color:#7d7f7e}A.brightgrey:active{color:#7d7f7e} A.brightgrey:hover{color:#f00}A.upnvl{color:#7d7f80} A.upnvl:visited{color:#7d7f80}A.upnvl:hover{color:#f00} A.btnvl{color:#7f90b0}A.btnvl:visited{color:#7f90b0} A.btnvl:hover{color:#f00}</style><table id=tbl_logos cellspacing=0 cetd width='46' align='left' style='line-height:12px;'><a href='http:// www.ynetnews.com/home/0,7340,L-3083,00.html' class='text11 btnvl'>English</a></td></tr></table></div></td><td width=11>&nbsp;</ td><td width=2 bgcolor=black></td><td width=11>&nbsp;</td><td width=132 valign=top style='direction: rtl;' class='ghci3' ><div id=divMainLogo style='margin-top:1px;'></div></td><td width=11><div style='width:11px;'></div></td><TD WIDTH=194 align=right dir=rtl VALIGN=top class='ghciTopStoryMain1' ><div dir=ltr style='height: 38px;overflow:hidden;'><IMG SRC='/Common/Files/Images/Date/12.gif' alt="12/04/2013 11:20"><IMG SRC='/Common/Files/Images/D... Friday, April 12, 13
  • 3. How Browsers Render • Each browser has a Rendering Engine • Rendering Engine takes an HTML text and produces a DOM tree Friday, April 12, 13
  • 4. Rendering Engines Engine Browser Developer Blink Google Chrome Google Gecko Mozilla Firefox Mozilla Trident IE Microsoft Apple, KDE, Nokia, Webkit Apple Safari Others Friday, April 12, 13
  • 5. How Browsers Work Parse HTML to make DOM Tree Build Render Tree from CSS Layout Elements Paint Friday, April 12, 13
  • 6. What’s a DOM Tree <html> <body> <p> Hello World </p> <div> <img src="example.png"/> </div> </body> </html> Friday, April 12, 13
  • 8. Rendering DOM Tree • A Render tree is derived from DOM tree • It’s not a 1-1 relation Friday, April 12, 13
  • 9. Browser Flow • Read page as text • Create DOM tree • Create Render tree • Paint Friday, April 12, 13
  • 10. Enter JavaScript • Read page as text • Create DOM tree JavaScript Manipulates the • Create Render tree data • Paint Friday, April 12, 13
  • 11. Enter JavaScript • JavaScript alters page load • JavaScript alters DOM Tree • JavaScript creates interactivity through events handling Friday, April 12, 13
  • 12. JavaScript and DOM <!DOCTYPE html> <html> <head>   <title></title> </head> <body> A <script> element is   <script>     var x = 5; executed in place     var y = 3;     console.log('Hello From JS');   </script>   <p>This is just some text</p> </body> </html> Friday, April 12, 13
  • 13. Q&A Browser Page Rendering Friday, April 12, 13
  • 14. Interactive Apps • Browser is a programming platform • A web application is interactive Friday, April 12, 13
  • 15. Interactivity • Browser itself is interactive • In addition: A web page is interactive • Demo Friday, April 12, 13
  • 16. Browser Events Loop Event Queue click Friday, April 12, 13
  • 17. Event Loop Wait for Events Handle Events Friday, April 12, 13
  • 18. Event Loop Wait for Events Handle Events Friday, April 12, 13
  • 19. Event Loop Wait for Events Handle Events Friday, April 12, 13
  • 20. Event Handling DOM Node + Event Handler (code) Event Friday, April 12, 13
  • 21. Code Outline • From HTML: • <a on...=”handleEvent()”> Friday, April 12, 13
  • 22. Code Outline • But this can get messy <a href="#" onclick="doclick"     onblur="doblur"     onchange="dochange"     ondblclick="dodblclick"     onmousemove="domove"     onmouseover="doover"> Too many events</a> Friday, April 12, 13
  • 23. Code Outline • From JS • Get a DOM node • Bind event to code Friday, April 12, 13
  • 24. Getting DOM Nodes • getElementById(...) • getElementsByTagName(...) • querySelector(...) - IE8 and up Friday, April 12, 13
  • 25. Browser Events • All browsers use: node.onevent = ... • IE uses: node.attachEvent(...) • Other browsers use node.addEventListener(...) Friday, April 12, 13
  • 26. Demo: Events • Write a simple page that shows alert as a response to click event • Modify to change text of element Friday, April 12, 13
  • 27. Using the Event Object • Event object includes info on the event • Print it to console for inspection   <button>Click Me</button>     <script>     var btn = document.getElementsByTagName('button')[0];     btn.onclick = function(e) {       if ( ! e ) e = window.event;         console.dir( e );     };   </script> Friday, April 12, 13
  • 28. Capturing vs. Bubbling | | / ---------------| |----------------- ---------------| |----------------- | element1 | | | | element1 | | | | -----------| |----------- | | -----------| |----------- | | |element2 / | | | |element2 | | | | | ------------------------- | | ------------------------- | | Event CAPTURING | | Event BUBBLING | ----------------------------------- ----------------------------------- Friday, April 12, 13
  • 29. Capturing vs. Bubbling | | / ---------------| |----------------- ---------------| |----------------- | element1 | | | | element1 | | | | -----------| |----------- | | -----------| |----------- | | |element2 / | | | |element2 | | | | | ------------------------- | | ------------------------- | | Event CAPTURING | | Event BUBBLING | ----------------------------------- ----------------------------------- Netscape Microsoft Friday, April 12, 13
  • 30. Capturing vs. Bubbling | | / -----------------| |--| |----------------- | element1 | | | | | | -------------| |--| |----------- | | |element2 / | | | | | -------------------------------- | | W3C event model | ------------------------------------------ Friday, April 12, 13
  • 31. Capturing vs. Bubbling • node.addEventListener takes a third parameter • true means capturing • false means bubbling • defaults to false Friday, April 12, 13
  • 32. Demo • Capture all click events using document.onclick = ... Friday, April 12, 13
  • 33. Usages • Default event handlers • Dynamic event handlers Friday, April 12, 13
  • 34. Double Handlers element1.onclick = Element2 doSomething; Element1 element2.onclick = doSomething; Friday, April 12, 13
  • 35. Double Handlers function doSomething(e) {       if ( ! e ) e = window.event; Element2         // this refers to Element1 // the current element       // for inner event: // this = element2       // for outer event: // this = element1 } Friday, April 12, 13
  • 36. Event Types Interface Events Mouse Events Form Events load, unload click, dblclick submit mousedown, mouseup, resize, scroll, reset mousemove focus, blur mouseover, mouseout Friday, April 12, 13
  • 37. Default Action • Some events also have a “default” action • For example: A link will take you to another page by default Friday, April 12, 13
  • 38. Default Action • Possible to prevent • return false from handler • Demo Friday, April 12, 13
  • 39. Q&A Handling Events Friday, April 12, 13
  • 40. Events Lab • Implement 5 duplicated input boxes • Each input box should have the same text • Change one -> all change automatically Friday, April 12, 13
  • 42. Altering Page Load • Change Document • Change DOM Tree • Change Render Tree Friday, April 12, 13
  • 43. Change Document • (Don’t) use document.write to change the document as it’s being loaded • Considered bad practice Friday, April 12, 13
  • 44. Change Document <!DOCTYPE html> <html> <head>   <title></title> </head> <body>   <script> document.write('<h1>Hello World</h1>'); </script>   <p>This is just some text</p> </body> </html> Friday, April 12, 13
  • 45. Change Document 1. Browser starts to create DOM tree body 2. Finds a script tag. script Stops to execute Friday, April 12, 13
  • 46. Change Document body 3. script added <h1> script h1 element to document Friday, April 12, 13
  • 47. Change Document body script h1 p 4. browser can continue to create the <p> Friday, April 12, 13
  • 48. Avoiding document.write • Can insert invalid content • Clobbers DOM if called after reading the document Friday, April 12, 13
  • 49. Friendlier Ways • Get a DOM node • Change it using DOM API Friday, April 12, 13
  • 50. Finding DOM Nodes Friday, April 12, 13
  • 51. DOM Traversal <body> body   <div>     <h1>Header</h1>     <p>       <img src="..." /> #text #div #text       Paragraph text       <a href="#">google</a> #text #text #h1 #text #p     </p>   </div> </body> Friday, April 12, 13
  • 52. DOM Traversal • n.childNodes[] • n.firstChild • n.lastChild • n.nextSibling • n.parentNode • n.previousSibling Friday, April 12, 13
  • 53. The (Past) Future • document.querySelector takes any CSS selector and fetches DOM element • Supported in IE8 and later Friday, April 12, 13
  • 54. DOM API • Allows • Getting info on elements • Changing element attributes • Creating new elements • Setting elements style Friday, April 12, 13
  • 55. DOM API • Use x.nodeName to get the tag name if ( this.nodeName === 'INPUT' ){   // handle input element } Friday, April 12, 13
  • 56. DOM API • Use x.nodeValue to get/set the node value a.firstChild.nodeValue = 'Go to google'; Friday, April 12, 13
  • 57. DOM API • Use getAttribute / setAttribute to change element attributes a.setAttribute('href', 'http://www.google.com'); Friday, April 12, 13
  • 58. Creating New Elements • Create elements and text nodes using document • Later you can add them to the DOM document.createElement('P'); document.createTextNode('Hello World'); Friday, April 12, 13
  • 59. Creating New Elements • Insert new nodes by manipulating existing // append y to x x.appendChild(y)   // insert y to x before z x.insertBefore(y,z)   // remove y from x x.removeChild(y)   // replace y with z x.replaceChild(y,z) Friday, April 12, 13
  • 60. Change Style • Use .style property to set an element style • Note style keys are almost like CSS property names p.style.backgroundColor = 'blue'; Friday, April 12, 13
  • 61. Q&A Handling Events Friday, April 12, 13
  • 62. DOM Lab • Given the HTML at: http://jsbin.com/ecitag/1/edit • Use JavaScript to: • write your name in the first <li> item of the second list • Change the H3 to H4 • Set all links to point to google.com Friday, April 12, 13
  • 63. DOM Lab • Create a Money Converter calculator • Support 3 currencies Friday, April 12, 13