SlideShare ist ein Scribd-Unternehmen logo
1 von 44
Fairfield Country JavaScript Meetup
       Wednesday Sept 26, 2012
About Jeff Fox

• Senior Software Engineer at [X+1]
• Self taught Web developer since 1997
• Also studied Art and Music Production
• Baseball enthusiast (ney fanatic)
• Twitter: @jfox015
Overview
• What is Dojo?

• Major components of the Dojo Toolkit

• Intro to [X+1] Origin

• Practical examples of Dojo usage in [X+1] Origin
  application

• Q&A
What is it?
What is Dojo?

• Powerful, feature rich JavaScript Toolkit

• Open Source and Community Driven

• One of the leading JS Frameworks along with
  Jquery, YUI, MooTools and Prototype

• Geared towards rapid web app development
Who is behind Dojo?




• Non-profit organization

• Open source community committers

• Industry leading technologists
Who is backing Dojo?
Why use Dojo?
•   Modern Browser Support
•   Full feature Mobile library (Dojo 1.7+)
•   Package Based
•   oAuth compatible
•   XMPP
•   2D and 3D FX Library
•   Namespaced, so it won’t conflict with
    other libraries.
Important support milestones
• IBM and Sun (now Oracle) announce support
  and contribute code

• Zend Technologies enters a partnership to
  integrate Dojo into the Zend Framework
Dojo Architecture
Dojo and Dojo Core
Calling Dojo

Local
<script type="text/javascript"
 src=“js/dojo/dojo.js"></script>
Google API
<script
 src="http://ajax.googleapis.com
 /ajax/libs/dojo/1.6.0/dojo/dojo
 .xd.js"></script>
Dojo Base
• Dojo.js – 90kb compressed (v 1.6.1)

• Initializes Dojo Bootstrap

• Built in host detection

• Class Package System
• Query, DOM, Ajax, Events, FX, Mobile
djConfig

<script type="text/javascript"
 src=“js/dojo/dojo.js“ data-
 dojo-config="isDebug: true,
 parseOnLoad: true"></script>

• Uses Firebug(if installed). Firebug Lite included
  if not
• Send messages via console.*()
Dojo Packages
• Include additional classes using dojo.require()
  – dojo.require(“dojo.store.Cache”);
  – Resolves to “pathtojs/dojo/store/Cache.js”
• Register and reuse a non-standard module
  path
  – dojo.registerModulePath(‘path2’,’a
    pth/to/js’);
  – dojo.require(“path2.ModuleName”);
Browser Detection
• Built in detection for modern browsers and
  technologies
•   dojo.isMoz           •   dojo.isKhtml
•   dojo.isFF            •   dojo.isWebKit
•   dojo.isIE            •   dojo.isSafari
•   dojo.isAIR           •   dojo.isChrome
•   dojo.isOpera         •   dojo.isQuirks
Classes and Inheritance
  • dojo.declare()
         – “Foundation of class creation. Allows for multiple
           inheritance to create flexible code and avoid
           writing the same code routines.” *


  dojo.declare("myClass",null,{
      // Custom code here
  });
* Source Classy JavaScript with dojo.declare, David Walsh
Classes and Inheritance
  • dojo.extend()
         – Add functionality and values to classes
  dojo.extend(myClass,{
      showUpper: function (msg) 
   { this.say(msg.toUpperCase()}; 
   }
  });
  var myc = new myClass();
  myc.showUpper(“hello”);
* Source Classy JavaScript with dojo.declare, David Walsh
Cool and useful functions
• dojo.mixin()
  – Utility function for mixing together objects
  – Powerful yet sometimes confusing function
  – Similar to extend(), but only works on objects


var objOne = { a: "first", b: 
 "second"}; 
dojo.mixin(objOne ,{c: ”Third”}});
Cool and useful functions
• dojo.hitch()
  – Utility function for simplifying context bindings
  – Creates a new function bound to a specific context
  – Can safely invoke without worrying about context
    changes
var myObject = { foo: "baz" }; 
var boundFunction = 
 dojo.hitch(myObject, function()
 {return "bar";});
Cool and useful functions
• dojo.query()
  – Uses familiar CSS queries (which you use in your
    stylesheets) to retrieve a list of nodes, including
    support for advanced CSS3 selectors
dojo.query(".odd").forEach(function
 (node, index, nodelist){
    dojo.addClass(node, "red");
});
More helpful DOM Functions
• dojo.byId()
  – Retrieve elements by DOM node id
• dojo.body()
  – Retrieve the HTML body element
• dojo.create()
• dojo.place()
• dojo.destroy()
  – Add and remove DOM nodes
Manipulate DOM nodes
• dojo.attr()
  – Get and set node attributes
• dojo.style()
  – Allows access to read and manipulate CSS styles.

<div id="poorboy3"></div>
<script type="dojo/method”>
dojo.style("poorboy3", "color", "red");
</script>
Events Support
• dojo.connect()
• dojo.disconnect()
  – Add event handling to objects
• dojo.subscribe()
• dojo.publish()
• dojo.unsubscribe()
  – Subscribe to and broadcast custom object events
Ajax
• dojo.xhr()
• dojo.xhrGet()
• dojo.xhrPost()
  – Standardized Ajax functionality
• dojo.Deferred()
  – Powerful tool for handling asynchronous operations
  – Deferred.then() allows for handling of both successful
    and error responses
• dojo. DeferredList() – Handle multiple Deferred
FX
• dojo.fadeIn()
• dojo.fadeOut()
  – Easy fade handlers
• dojo.animateProperty()
  – Animate a node according to set parameters
Dojo Core
• dojo.data                  • Utilities
   – Unified Data API           – dojo.string
• dojo.dnd                      – dojo.date
   – Drag and Drop Support      – dojo.regexp
• dojo.fx                    • I/O
   – Advanced FX Library        – dojo.io.iframe
• dojo.i18n                     – dojo.io.script
   – Internationalization       – dojo.rpc
• OpenAjax                   • dojo.back
                                – Browser History
Dijit
What is Dijit?
• Dojo Widget and Component Library
• Large library of prebuilt and tested widgets
  – Form Element Library
     • Buttons, select boxes, inputs, radios, checkboxes, etc.
  – Layout Widgets
     • Content Pan, Accordians, tabbed containers, stacks, etc
  – Experience Widgets
     • Tree, progress bar, dialogs, tooltips, menus, advanced
       text boxes
What is Dijit?
• Fully accessible
• Built in Template Support
  – Can utilize external HTML Templates when
    building dojo widgets
• Theme Support
  – Tundra, Soria, Nihilo, Noir
Declarative Instantiations
• Can declare a DOM element as a Dijit Widget
  by means of dojoType
  – For v 1.7 and up, it is now dojo-type

<textarea dojoAttachPoint="campNotes" 
  name="campNotes" 
  dojoType="dijit.form.Textarea" 
  class="campNotes"></textarea>
Programmatic Instantiations
• Create new Dijit Widgets via JS new and place
  or insert into HTML output
var mts = new 
  dijit.form.MultiSelect({ multip
  le: 'multiple', size: 10, name: 
  ‘costsList' }, this.formNode);
Widget Lifecycle
•   constructor()
•   postMixInProperties()
•   buildRendering()
•   postCreate()
•   startup()
Dijit Shortcuts
• Form. get(“value”)
  – Automatically access the values of all form
    elements that have a value attribute
  – Use dojo.mixin() to further add form data for
    submission
  – Use dojo.hitch() to add additional form validation
    and error handling
Helpful Layout Widgets
•   BorderContainer
•   ContentPane
•   LinkPane
•   TabContainer
•   AccordianContainer
•   SplitContainer
•   StackContainer
DojoX
What is DojoX
• DojoX is the Dojo breeding or playground.
• Contains widgets, classes and utilities that are
  not yet deemed ready for inclusion in the
  main Dojo library
• Contains experimental widgets and elements,
  most notable being the Dojo Grid widget
What’s in DojoX?
•   Analytics           •   I/O
•   Charting            •   More Data Stores
•   CometD              •   Language
•   Drawing             •   Layout
•   Editors             •   Mobile(!)
•   More Form Widgets   •   Testing
•   The Grid            •   Widgets
•   2D/3D gFx           •   XMPP
Dojo Mobile
Dojo Mobile
• Device ready Dojo JS library
• Pre-Built Themes for iOS and Android
• Leverage existing Dojo knowledge when
  building for mobile devices
Dojo Mobile Example
<div id="general" 
dojoType="dojox.mobile.View"><h1 
dojoType="dojox.mobile.Heading" 
back="Settings" moveTo="settings">General 
View</h1>
<ul dojoType="dojox.mobile.RoundRectList">
<li dojoType="dojox.mobile.ListItem" 
moveTo="about">
About
</li>
</ul>
</div>
Util
Dojo Util
• DOH – Built in Unit Testing Tool
Q&A

Weitere ähnliche Inhalte

Was ist angesagt?

Moving to Dojo 1.7 and the path to 2.0
Moving to Dojo 1.7 and the path to 2.0Moving to Dojo 1.7 and the path to 2.0
Moving to Dojo 1.7 and the path to 2.0James Thomas
 
Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014
Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014
Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014Endava
 
How dojo works
How dojo worksHow dojo works
How dojo worksAmit Tyagi
 
Building Real-World Dojo Web Applications
Building Real-World Dojo Web ApplicationsBuilding Real-World Dojo Web Applications
Building Real-World Dojo Web ApplicationsAndrew Ferrier
 
Rich internet application development using the dojo toolkit
Rich internet application development using the dojo toolkitRich internet application development using the dojo toolkit
Rich internet application development using the dojo toolkitalexklaeser
 
Building Dojo in the Cloud
Building Dojo in the CloudBuilding Dojo in the Cloud
Building Dojo in the CloudJames Thomas
 
jQuery Tips Tricks Trivia
jQuery Tips Tricks TriviajQuery Tips Tricks Trivia
jQuery Tips Tricks TriviaCognizant
 
BP210 XPages: Enter The Dojo
BP210 XPages: Enter The DojoBP210 XPages: Enter The Dojo
BP210 XPages: Enter The DojoPaul Withers
 
XPages Binary Output
XPages Binary OutputXPages Binary Output
XPages Binary OutputJohnFoldager
 
How browser engines work?
How browser engines work?How browser engines work?
How browser engines work?haricot
 
JavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your codeJavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your codeLaurence Svekis ✔
 
Introduction to jQuery
Introduction to jQueryIntroduction to jQuery
Introduction to jQueryAlek Davis
 
JavaScript Library Overview (Ajax Exp West 2007)
JavaScript Library Overview (Ajax Exp West 2007)JavaScript Library Overview (Ajax Exp West 2007)
JavaScript Library Overview (Ajax Exp West 2007)jeresig
 
Starting with jQuery
Starting with jQueryStarting with jQuery
Starting with jQueryAnil Kumar
 
Introduction to jQuery (Ajax Exp 2007)
Introduction to jQuery (Ajax Exp 2007)Introduction to jQuery (Ajax Exp 2007)
Introduction to jQuery (Ajax Exp 2007)jeresig
 

Was ist angesagt? (18)

Moving to Dojo 1.7 and the path to 2.0
Moving to Dojo 1.7 and the path to 2.0Moving to Dojo 1.7 and the path to 2.0
Moving to Dojo 1.7 and the path to 2.0
 
Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014
Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014
Angularjs vs Dojo toolkit | SuperSpeaker@CodeCamp Iasi 2014
 
How dojo works
How dojo worksHow dojo works
How dojo works
 
Building Real-World Dojo Web Applications
Building Real-World Dojo Web ApplicationsBuilding Real-World Dojo Web Applications
Building Real-World Dojo Web Applications
 
Rich internet application development using the dojo toolkit
Rich internet application development using the dojo toolkitRich internet application development using the dojo toolkit
Rich internet application development using the dojo toolkit
 
Building Dojo in the Cloud
Building Dojo in the CloudBuilding Dojo in the Cloud
Building Dojo in the Cloud
 
jQuery Tips Tricks Trivia
jQuery Tips Tricks TriviajQuery Tips Tricks Trivia
jQuery Tips Tricks Trivia
 
BP210 XPages: Enter The Dojo
BP210 XPages: Enter The DojoBP210 XPages: Enter The Dojo
BP210 XPages: Enter The Dojo
 
dojo.Patterns
dojo.Patternsdojo.Patterns
dojo.Patterns
 
XPages Binary Output
XPages Binary OutputXPages Binary Output
XPages Binary Output
 
How browser engines work?
How browser engines work?How browser engines work?
How browser engines work?
 
The jQuery Library
The  jQuery LibraryThe  jQuery Library
The jQuery Library
 
JavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your codeJavaScript Advanced - Useful methods to power up your code
JavaScript Advanced - Useful methods to power up your code
 
jQuery-3-UI
jQuery-3-UIjQuery-3-UI
jQuery-3-UI
 
Introduction to jQuery
Introduction to jQueryIntroduction to jQuery
Introduction to jQuery
 
JavaScript Library Overview (Ajax Exp West 2007)
JavaScript Library Overview (Ajax Exp West 2007)JavaScript Library Overview (Ajax Exp West 2007)
JavaScript Library Overview (Ajax Exp West 2007)
 
Starting with jQuery
Starting with jQueryStarting with jQuery
Starting with jQuery
 
Introduction to jQuery (Ajax Exp 2007)
Introduction to jQuery (Ajax Exp 2007)Introduction to jQuery (Ajax Exp 2007)
Introduction to jQuery (Ajax Exp 2007)
 

Andere mochten auch

Common Practices in Religion
Common Practices in ReligionCommon Practices in Religion
Common Practices in ReligionStacey Troup
 
Certificate in hardware networking
Certificate in  hardware networkingCertificate in  hardware networking
Certificate in hardware networkingignounict
 
Motor vehicle sale agreement
Motor vehicle sale agreementMotor vehicle sale agreement
Motor vehicle sale agreementManesa George
 
Significance of CAP accreditation
Significance of CAP accreditationSignificance of CAP accreditation
Significance of CAP accreditationBilal Al-kadri
 
Ruby on Big Data (Cassandra + Hadoop)
Ruby on Big Data (Cassandra + Hadoop)Ruby on Big Data (Cassandra + Hadoop)
Ruby on Big Data (Cassandra + Hadoop)Brian O'Neill
 
ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...
ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...
ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...NAMSA
 
Types of Insurance Policies Owned by Singaporeans
Types of Insurance Policies Owned by SingaporeansTypes of Insurance Policies Owned by Singaporeans
Types of Insurance Policies Owned by SingaporeansChew Zhan Lun
 
Performance Management System in Bank Assignment Sample
Performance Management System in Bank Assignment SamplePerformance Management System in Bank Assignment Sample
Performance Management System in Bank Assignment SampleGlobal Assignment Help
 
overview of banking sector & growth and structure
overview of banking sector & growth  and structureoverview of banking sector & growth  and structure
overview of banking sector & growth and structureAnil Beniwal
 
Accounting Standard-3 Cash Flow Statement by Nithin Raj
Accounting Standard-3 Cash Flow Statement by Nithin RajAccounting Standard-3 Cash Flow Statement by Nithin Raj
Accounting Standard-3 Cash Flow Statement by Nithin RajChinnu Raj
 
해킹 대회 리뷰 및 실전 해킹
해킹 대회 리뷰 및 실전 해킹해킹 대회 리뷰 및 실전 해킹
해킹 대회 리뷰 및 실전 해킹totodeung
 
Ceph Intro and Architectural Overview by Ross Turk
Ceph Intro and Architectural Overview by Ross TurkCeph Intro and Architectural Overview by Ross Turk
Ceph Intro and Architectural Overview by Ross Turkbuildacloud
 
Second Grade Science: Plants
Second Grade Science: PlantsSecond Grade Science: Plants
Second Grade Science: PlantsKathyFiol
 
Effective Automation 〜変化に強い開発基盤〜
Effective Automation 〜変化に強い開発基盤〜Effective Automation 〜変化に強い開発基盤〜
Effective Automation 〜変化に強い開発基盤〜Jumpei Miyata
 
Digital Marketing Strategic Framework
Digital Marketing Strategic FrameworkDigital Marketing Strategic Framework
Digital Marketing Strategic FrameworkJanet Jaiswal
 

Andere mochten auch (18)

Common Practices in Religion
Common Practices in ReligionCommon Practices in Religion
Common Practices in Religion
 
Certificate in hardware networking
Certificate in  hardware networkingCertificate in  hardware networking
Certificate in hardware networking
 
Motor vehicle sale agreement
Motor vehicle sale agreementMotor vehicle sale agreement
Motor vehicle sale agreement
 
Effective intercultural communication
Effective intercultural communicationEffective intercultural communication
Effective intercultural communication
 
Significance of CAP accreditation
Significance of CAP accreditationSignificance of CAP accreditation
Significance of CAP accreditation
 
Ruby on Big Data (Cassandra + Hadoop)
Ruby on Big Data (Cassandra + Hadoop)Ruby on Big Data (Cassandra + Hadoop)
Ruby on Big Data (Cassandra + Hadoop)
 
ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...
ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...
ISO 10993-7 Biological Evaluation of Medical Devices - Ethylene Oxide Sterili...
 
Types of Insurance Policies Owned by Singaporeans
Types of Insurance Policies Owned by SingaporeansTypes of Insurance Policies Owned by Singaporeans
Types of Insurance Policies Owned by Singaporeans
 
Endowment Policy
Endowment PolicyEndowment Policy
Endowment Policy
 
Performance Management System in Bank Assignment Sample
Performance Management System in Bank Assignment SamplePerformance Management System in Bank Assignment Sample
Performance Management System in Bank Assignment Sample
 
overview of banking sector & growth and structure
overview of banking sector & growth  and structureoverview of banking sector & growth  and structure
overview of banking sector & growth and structure
 
Accounting Standard-3 Cash Flow Statement by Nithin Raj
Accounting Standard-3 Cash Flow Statement by Nithin RajAccounting Standard-3 Cash Flow Statement by Nithin Raj
Accounting Standard-3 Cash Flow Statement by Nithin Raj
 
해킹 대회 리뷰 및 실전 해킹
해킹 대회 리뷰 및 실전 해킹해킹 대회 리뷰 및 실전 해킹
해킹 대회 리뷰 및 실전 해킹
 
Ceph Intro and Architectural Overview by Ross Turk
Ceph Intro and Architectural Overview by Ross TurkCeph Intro and Architectural Overview by Ross Turk
Ceph Intro and Architectural Overview by Ross Turk
 
Second Grade Science: Plants
Second Grade Science: PlantsSecond Grade Science: Plants
Second Grade Science: Plants
 
Effective Automation 〜変化に強い開発基盤〜
Effective Automation 〜変化に強い開発基盤〜Effective Automation 〜変化に強い開発基盤〜
Effective Automation 〜変化に強い開発基盤〜
 
Digital Marketing Strategic Framework
Digital Marketing Strategic FrameworkDigital Marketing Strategic Framework
Digital Marketing Strategic Framework
 
SCgame2
SCgame2SCgame2
SCgame2
 

Ähnlich wie The Dojo Toolkit An Introduction

Getting Started with Dojo Toolkit
Getting Started with Dojo ToolkitGetting Started with Dojo Toolkit
Getting Started with Dojo ToolkitThomas Koch
 
Dojo for programmers (TXJS 2010)
Dojo for programmers (TXJS 2010)Dojo for programmers (TXJS 2010)
Dojo for programmers (TXJS 2010)Eugene Lazutkin
 
Jquery dojo slides
Jquery dojo slidesJquery dojo slides
Jquery dojo slideshelenmga
 
Dojo GFX workshop slides
Dojo GFX workshop slidesDojo GFX workshop slides
Dojo GFX workshop slidesEugene Lazutkin
 
JavaScript Libraries (Ajax Exp 2006)
JavaScript Libraries (Ajax Exp 2006)JavaScript Libraries (Ajax Exp 2006)
JavaScript Libraries (Ajax Exp 2006)jeresig
 
Dojo and Zend Framework
Dojo and Zend  FrameworkDojo and Zend  Framework
Dojo and Zend FrameworkKuldeep Singh
 
Dojo: Beautiful Web Apps, Fast
Dojo: Beautiful Web Apps, FastDojo: Beautiful Web Apps, Fast
Dojo: Beautiful Web Apps, FastGabriel Hamilton
 
jQuery Learning
jQuery LearningjQuery Learning
jQuery LearningUzair Ali
 
jQuery - the world's most popular java script library comes to XPages
jQuery - the world's most popular java script library comes to XPagesjQuery - the world's most popular java script library comes to XPages
jQuery - the world's most popular java script library comes to XPagesMark Roden
 
How to start developing apps for Firefox OS
How to start developing apps for Firefox OSHow to start developing apps for Firefox OS
How to start developing apps for Firefox OSbenko
 
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)Doris Chen
 
Microsoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptx
Microsoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptxMicrosoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptx
Microsoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptxtutorialsruby
 

Ähnlich wie The Dojo Toolkit An Introduction (20)

Dojo training
Dojo trainingDojo training
Dojo training
 
Getting Started with Dojo Toolkit
Getting Started with Dojo ToolkitGetting Started with Dojo Toolkit
Getting Started with Dojo Toolkit
 
Dojo for programmers (TXJS 2010)
Dojo for programmers (TXJS 2010)Dojo for programmers (TXJS 2010)
Dojo for programmers (TXJS 2010)
 
Jquery dojo slides
Jquery dojo slidesJquery dojo slides
Jquery dojo slides
 
Dojo GFX workshop slides
Dojo GFX workshop slidesDojo GFX workshop slides
Dojo GFX workshop slides
 
JavaScript Libraries (Ajax Exp 2006)
JavaScript Libraries (Ajax Exp 2006)JavaScript Libraries (Ajax Exp 2006)
JavaScript Libraries (Ajax Exp 2006)
 
Test02
Test02Test02
Test02
 
Dojo and Zend Framework
Dojo and Zend  FrameworkDojo and Zend  Framework
Dojo and Zend Framework
 
Pulsar
PulsarPulsar
Pulsar
 
Jquery fundamentals
Jquery fundamentalsJquery fundamentals
Jquery fundamentals
 
Dojo: Beautiful Web Apps, Fast
Dojo: Beautiful Web Apps, FastDojo: Beautiful Web Apps, Fast
Dojo: Beautiful Web Apps, Fast
 
jQuery Learning
jQuery LearningjQuery Learning
jQuery Learning
 
jQuery - the world's most popular java script library comes to XPages
jQuery - the world's most popular java script library comes to XPagesjQuery - the world's most popular java script library comes to XPages
jQuery - the world's most popular java script library comes to XPages
 
DOJO
DOJO DOJO
DOJO
 
How to start developing apps for Firefox OS
How to start developing apps for Firefox OSHow to start developing apps for Firefox OS
How to start developing apps for Firefox OS
 
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)
jQuery Makes Writing JavaScript Fun Again (for HTML5 User Group)
 
jQuery-3-UI
jQuery-3-UIjQuery-3-UI
jQuery-3-UI
 
JQuery-Tutorial
 JQuery-Tutorial JQuery-Tutorial
JQuery-Tutorial
 
Microsoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptx
Microsoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptxMicrosoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptx
Microsoft PowerPoint - &lt;b>jQuery&lt;/b>-3-UI.pptx
 
Ios development
Ios developmentIos development
Ios development
 

Kürzlich hochgeladen

04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationSafe Software
 
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfThe Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfEnterprise Knowledge
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Allon Mureinik
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)Gabriella Davis
 
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
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Drew Madelung
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...shyamraj55
 
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
 
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
 
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
 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationRadu Cotescu
 
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
 
#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
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slidevu2urc
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure servicePooja Nehwal
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGSujit Pal
 
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
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Servicegiselly40
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityPrincipled Technologies
 

Kürzlich hochgeladen (20)

04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfThe Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
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
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
 
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
 
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
 
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
 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organization
 
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 ...
 
#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
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
 
Google AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAGGoogle AI Hackathon: LLM based Evaluator for RAG
Google AI Hackathon: LLM based Evaluator for RAG
 
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...
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 

The Dojo Toolkit An Introduction

  • 1. Fairfield Country JavaScript Meetup Wednesday Sept 26, 2012
  • 2. About Jeff Fox • Senior Software Engineer at [X+1] • Self taught Web developer since 1997 • Also studied Art and Music Production • Baseball enthusiast (ney fanatic) • Twitter: @jfox015
  • 3. Overview • What is Dojo? • Major components of the Dojo Toolkit • Intro to [X+1] Origin • Practical examples of Dojo usage in [X+1] Origin application • Q&A
  • 5. What is Dojo? • Powerful, feature rich JavaScript Toolkit • Open Source and Community Driven • One of the leading JS Frameworks along with Jquery, YUI, MooTools and Prototype • Geared towards rapid web app development
  • 6. Who is behind Dojo? • Non-profit organization • Open source community committers • Industry leading technologists
  • 8. Why use Dojo? • Modern Browser Support • Full feature Mobile library (Dojo 1.7+) • Package Based • oAuth compatible • XMPP • 2D and 3D FX Library • Namespaced, so it won’t conflict with other libraries.
  • 9. Important support milestones • IBM and Sun (now Oracle) announce support and contribute code • Zend Technologies enters a partnership to integrate Dojo into the Zend Framework
  • 12. Calling Dojo Local <script type="text/javascript" src=“js/dojo/dojo.js"></script> Google API <script src="http://ajax.googleapis.com /ajax/libs/dojo/1.6.0/dojo/dojo .xd.js"></script>
  • 13. Dojo Base • Dojo.js – 90kb compressed (v 1.6.1) • Initializes Dojo Bootstrap • Built in host detection • Class Package System • Query, DOM, Ajax, Events, FX, Mobile
  • 14. djConfig <script type="text/javascript" src=“js/dojo/dojo.js“ data- dojo-config="isDebug: true, parseOnLoad: true"></script> • Uses Firebug(if installed). Firebug Lite included if not • Send messages via console.*()
  • 15. Dojo Packages • Include additional classes using dojo.require() – dojo.require(“dojo.store.Cache”); – Resolves to “pathtojs/dojo/store/Cache.js” • Register and reuse a non-standard module path – dojo.registerModulePath(‘path2’,’a pth/to/js’); – dojo.require(“path2.ModuleName”);
  • 16. Browser Detection • Built in detection for modern browsers and technologies • dojo.isMoz • dojo.isKhtml • dojo.isFF • dojo.isWebKit • dojo.isIE • dojo.isSafari • dojo.isAIR • dojo.isChrome • dojo.isOpera • dojo.isQuirks
  • 17. Classes and Inheritance • dojo.declare() – “Foundation of class creation. Allows for multiple inheritance to create flexible code and avoid writing the same code routines.” * dojo.declare("myClass",null,{     // Custom code here }); * Source Classy JavaScript with dojo.declare, David Walsh
  • 18. Classes and Inheritance • dojo.extend() – Add functionality and values to classes dojo.extend(myClass,{     showUpper: function (msg)  { this.say(msg.toUpperCase()};  } }); var myc = new myClass(); myc.showUpper(“hello”); * Source Classy JavaScript with dojo.declare, David Walsh
  • 19. Cool and useful functions • dojo.mixin() – Utility function for mixing together objects – Powerful yet sometimes confusing function – Similar to extend(), but only works on objects var objOne = { a: "first", b:  "second"};  dojo.mixin(objOne ,{c: ”Third”}});
  • 20. Cool and useful functions • dojo.hitch() – Utility function for simplifying context bindings – Creates a new function bound to a specific context – Can safely invoke without worrying about context changes var myObject = { foo: "baz" };  var boundFunction =  dojo.hitch(myObject, function() {return "bar";});
  • 21. Cool and useful functions • dojo.query() – Uses familiar CSS queries (which you use in your stylesheets) to retrieve a list of nodes, including support for advanced CSS3 selectors dojo.query(".odd").forEach(function (node, index, nodelist){ dojo.addClass(node, "red"); });
  • 22. More helpful DOM Functions • dojo.byId() – Retrieve elements by DOM node id • dojo.body() – Retrieve the HTML body element • dojo.create() • dojo.place() • dojo.destroy() – Add and remove DOM nodes
  • 23. Manipulate DOM nodes • dojo.attr() – Get and set node attributes • dojo.style() – Allows access to read and manipulate CSS styles. <div id="poorboy3"></div> <script type="dojo/method”> dojo.style("poorboy3", "color", "red"); </script>
  • 24. Events Support • dojo.connect() • dojo.disconnect() – Add event handling to objects • dojo.subscribe() • dojo.publish() • dojo.unsubscribe() – Subscribe to and broadcast custom object events
  • 25. Ajax • dojo.xhr() • dojo.xhrGet() • dojo.xhrPost() – Standardized Ajax functionality • dojo.Deferred() – Powerful tool for handling asynchronous operations – Deferred.then() allows for handling of both successful and error responses • dojo. DeferredList() – Handle multiple Deferred
  • 26. FX • dojo.fadeIn() • dojo.fadeOut() – Easy fade handlers • dojo.animateProperty() – Animate a node according to set parameters
  • 27. Dojo Core • dojo.data • Utilities – Unified Data API – dojo.string • dojo.dnd – dojo.date – Drag and Drop Support – dojo.regexp • dojo.fx • I/O – Advanced FX Library – dojo.io.iframe • dojo.i18n – dojo.io.script – Internationalization – dojo.rpc • OpenAjax • dojo.back – Browser History
  • 28. Dijit
  • 29. What is Dijit? • Dojo Widget and Component Library • Large library of prebuilt and tested widgets – Form Element Library • Buttons, select boxes, inputs, radios, checkboxes, etc. – Layout Widgets • Content Pan, Accordians, tabbed containers, stacks, etc – Experience Widgets • Tree, progress bar, dialogs, tooltips, menus, advanced text boxes
  • 30. What is Dijit? • Fully accessible • Built in Template Support – Can utilize external HTML Templates when building dojo widgets • Theme Support – Tundra, Soria, Nihilo, Noir
  • 31. Declarative Instantiations • Can declare a DOM element as a Dijit Widget by means of dojoType – For v 1.7 and up, it is now dojo-type <textarea dojoAttachPoint="campNotes"  name="campNotes"  dojoType="dijit.form.Textarea"  class="campNotes"></textarea>
  • 32. Programmatic Instantiations • Create new Dijit Widgets via JS new and place or insert into HTML output var mts = new  dijit.form.MultiSelect({ multip le: 'multiple', size: 10, name:  ‘costsList' }, this.formNode);
  • 33. Widget Lifecycle • constructor() • postMixInProperties() • buildRendering() • postCreate() • startup()
  • 34. Dijit Shortcuts • Form. get(“value”) – Automatically access the values of all form elements that have a value attribute – Use dojo.mixin() to further add form data for submission – Use dojo.hitch() to add additional form validation and error handling
  • 35. Helpful Layout Widgets • BorderContainer • ContentPane • LinkPane • TabContainer • AccordianContainer • SplitContainer • StackContainer
  • 36. DojoX
  • 37. What is DojoX • DojoX is the Dojo breeding or playground. • Contains widgets, classes and utilities that are not yet deemed ready for inclusion in the main Dojo library • Contains experimental widgets and elements, most notable being the Dojo Grid widget
  • 38. What’s in DojoX? • Analytics • I/O • Charting • More Data Stores • CometD • Language • Drawing • Layout • Editors • Mobile(!) • More Form Widgets • Testing • The Grid • Widgets • 2D/3D gFx • XMPP
  • 40. Dojo Mobile • Device ready Dojo JS library • Pre-Built Themes for iOS and Android • Leverage existing Dojo knowledge when building for mobile devices
  • 42. Util
  • 43. Dojo Util • DOH – Built in Unit Testing Tool
  • 44. Q&A