SlideShare une entreprise Scribd logo
1  sur  32
James Senior - Microsoft Web Evangelist@jsenior - www.jamessenior.com
Microsoft & jQuery: A True Love Story
A few months ago…
Once upon a time… 1997: Classic ASP 1, 2, 3 2002: ASP.NET 1.0 and WebForms Ajax Control Toolkit 2003 to 2007: ASP.NET 1.1, 2, 3, 3.5 2008: Visual Studio 2008 - including jQuery 2008: Official Support for jQuery 2009: ASP.NET MVC – including jQuery 2009: ASP.NET Ajax Library 2009: jQuery on the Microsoft CDN 2010: ASP.NET 4 – including jQuery
Visual studio 2010(now with better Javascript support) Demo-tastic
Back in February, it was just another day at work
ASP.NET Ajax Library Open Source JavaScript Library Cool features, including Script Loader Data-Linking Observer class Templating Data Controls jQuery integration
Perfect Match jQuery ASP.NET Ajax Templating Data-Linking Script Loader WCF  OData .NET RIA  Selectors Plugins  Animation
First Date
All good relationships… Have a clear contribution model Are open, transparent and collaborative Are in the spirit of jQuerycommunity Have specification & Proposals on jQuery Forums  Have prototypes as plugins in Github jQuery Core Cool stuff ++ jQuery Core Team ASP.NET Ajax Library Cool Stuff jQuery Plugins Cool stuff Proposal, Specification, Prototype
jQueryTemplating 1stcontribution from Microsoft Proposal, Spec and Prototype online http://github.com/jquery/jquery-tmpl
The Contribution model in action…
What is Templating? Data Templating Engine DOM Template
Why client-side templates? Aren’t server side templates good enough? Couldn’t I do this before?
What is a Template? vartmpl = "<li>${ dataItem }</li>";
What is a Template? <script id=“myTemplate" type="text/html"> 	<li>${ dataItem }</li> </script>
What is a Template? <script id="productsTemplate" type="text/html">  <div> <imgsrc="Content/ProductImages/${Picture}" class="productImage" /> <span class="productName">${Name}</span>       Price: ${formatPrice(Price)}      <img data-pk="${Id}" src="Content/AddCart.png"           alt="Add to Cart" class="addCart" />  </div> </script>
.render() <script id=“myTemplate" type="text/html"> 	<li>${ dataItem }</li> </script> $("#myTemplate") .render( dataObject) .appendTo("ul"); <ul> <li>foo</li> </ul>
.render() <script id=“myTemplate" type="text/html"> 	<li>${ dataItem }</li> </script> $("#myTemplate") .render( arrayOfDataObjects ) .appendTo("ul"); <ul> <li>foo_0</li> <li>foo_1</li> </ul>
jQueryTemplating Can I haz demo?
And then there was more…
jQuery Data Linking Sync data and UI
jQuery Data Linking Golden Rule - modify data using jQuery
Data linking Demo Fest
Wait a minute… What about the ASP.NET Ajax Library? It’s now RTM quality code Resides in Ajax Control Toolkit (still an open source project) Still served on the CDN We are not actively developing new features
This love story is to be continued…
More Love: Web Camps Update Free, 2 day events – Learn and Build 3000 people in 12 cities More events being announced after the summer www.webcamps.ms
How to find your love Check out the proposals, specs and prototypes  Give your feedback to the community Tell a friend about what you heard today Get free tooling http://microsoft.com/web Come along to a Web Camp www.webcamps.ms Slides and demos are on my blog…
Contact Me James SeniorMicrosoft Web Evangelist @jsenior james@microsoft.com www.jamessenior.com

Contenu connexe

Tendances

Tendances (20)

Gettings started with the superheroic JavaScript library AngularJS
Gettings started with the superheroic JavaScript library AngularJSGettings started with the superheroic JavaScript library AngularJS
Gettings started with the superheroic JavaScript library AngularJS
 
AngularJS interview questions
AngularJS interview questionsAngularJS interview questions
AngularJS interview questions
 
AngularJS
AngularJSAngularJS
AngularJS
 
Angularjs PPT
Angularjs PPTAngularjs PPT
Angularjs PPT
 
Introduction to AngularJS
Introduction to AngularJSIntroduction to AngularJS
Introduction to AngularJS
 
Advanced AngularJS Concepts
Advanced AngularJS ConceptsAdvanced AngularJS Concepts
Advanced AngularJS Concepts
 
Angularjs interview questions and answers
Angularjs interview questions and answersAngularjs interview questions and answers
Angularjs interview questions and answers
 
Jquery mobile
Jquery mobileJquery mobile
Jquery mobile
 
Angular 2 interview questions and answers
Angular 2 interview questions and answersAngular 2 interview questions and answers
Angular 2 interview questions and answers
 
Angular js PPT
Angular js PPTAngular js PPT
Angular js PPT
 
Angular js
Angular jsAngular js
Angular js
 
Javascript
JavascriptJavascript
Javascript
 
Angular js getting started
Angular js getting startedAngular js getting started
Angular js getting started
 
AngularJS is awesome
AngularJS is awesomeAngularJS is awesome
AngularJS is awesome
 
Introduction to AngularJS Framework
Introduction to AngularJS FrameworkIntroduction to AngularJS Framework
Introduction to AngularJS Framework
 
Angular.js interview questions
Angular.js interview questionsAngular.js interview questions
Angular.js interview questions
 
Visual Studio 2010 Ultimate Architecture Experience : Toronto Code Camp 2010 ...
Visual Studio 2010 Ultimate Architecture Experience : Toronto Code Camp 2010 ...Visual Studio 2010 Ultimate Architecture Experience : Toronto Code Camp 2010 ...
Visual Studio 2010 Ultimate Architecture Experience : Toronto Code Camp 2010 ...
 
Will your code blend? : Toronto Code Camp 2010 : Barry Gervin
Will your code blend? : Toronto Code Camp 2010 : Barry GervinWill your code blend? : Toronto Code Camp 2010 : Barry Gervin
Will your code blend? : Toronto Code Camp 2010 : Barry Gervin
 
Android training day 1
Android training day 1Android training day 1
Android training day 1
 
AngularJS: Overview & Key Features
AngularJS: Overview & Key FeaturesAngularJS: Overview & Key Features
AngularJS: Overview & Key Features
 

En vedette

True Love = One Family at A Time
True Love = One Family at A Time True Love = One Family at A Time
True Love = One Family at A Time
GPFIndonesia
 
Story to be continued
Story to be continuedStory to be continued
Story to be continued
John Pooley
 
Love story true love final
Love story true love finalLove story true love final
Love story true love final
DS_Shrewsbury
 
The Twelve Days Of Christmas
The Twelve Days Of ChristmasThe Twelve Days Of Christmas
The Twelve Days Of Christmas
David Deubelbeiss
 
TRUE LOVE WAITS
TRUE LOVE WAITS TRUE LOVE WAITS
TRUE LOVE WAITS
SFYC
 
Introduction to Design Thinking and finding True Love
Introduction to Design Thinking and finding True LoveIntroduction to Design Thinking and finding True Love
Introduction to Design Thinking and finding True Love
coleman yee
 

En vedette (20)

True Love
True LoveTrue Love
True Love
 
True Love = One Family at A Time
True Love = One Family at A Time True Love = One Family at A Time
True Love = One Family at A Time
 
429 - True love
429 - True love429 - True love
429 - True love
 
How do you find true love? Intermediate English project
How do you find true love? Intermediate English projectHow do you find true love? Intermediate English project
How do you find true love? Intermediate English project
 
True Love
True LoveTrue Love
True Love
 
True Love
True LoveTrue Love
True Love
 
Story to be continued
Story to be continuedStory to be continued
Story to be continued
 
Love and trust
Love and trustLove and trust
Love and trust
 
True love
True loveTrue love
True love
 
Love story true love final
Love story true love finalLove story true love final
Love story true love final
 
LESSONS FROM THE NEEDLE IN THE HAYSTACK - FIND TRUE LOVE
LESSONS FROM THE NEEDLE IN THE HAYSTACK - FIND TRUE LOVELESSONS FROM THE NEEDLE IN THE HAYSTACK - FIND TRUE LOVE
LESSONS FROM THE NEEDLE IN THE HAYSTACK - FIND TRUE LOVE
 
The Twelve Beers Of Christmas
The Twelve Beers Of ChristmasThe Twelve Beers Of Christmas
The Twelve Beers Of Christmas
 
The Twelve Days Of Christmas
The Twelve Days Of ChristmasThe Twelve Days Of Christmas
The Twelve Days Of Christmas
 
TRUE LOVE WAITS
TRUE LOVE WAITS TRUE LOVE WAITS
TRUE LOVE WAITS
 
Introduction to Design Thinking and finding True Love
Introduction to Design Thinking and finding True LoveIntroduction to Design Thinking and finding True Love
Introduction to Design Thinking and finding True Love
 
Prava Ljubav
Prava LjubavPrava Ljubav
Prava Ljubav
 
TRUE LOVE WAITS
TRUE LOVE WAITSTRUE LOVE WAITS
TRUE LOVE WAITS
 
True love waits
True love waitsTrue love waits
True love waits
 
Love Me Tender... Love Me True... 2009
Love Me Tender... Love Me True...   2009Love Me Tender... Love Me True...   2009
Love Me Tender... Love Me True... 2009
 
FINDING TRUE LOVE IN THE MEDIA -- THEOLOGY OF THE BODY
FINDING TRUE LOVE IN THE MEDIA -- THEOLOGY OF THE BODYFINDING TRUE LOVE IN THE MEDIA -- THEOLOGY OF THE BODY
FINDING TRUE LOVE IN THE MEDIA -- THEOLOGY OF THE BODY
 

Similaire à Microsoft and jQuery: A true love story - templating and other contributions

Open social 2.0 sandbox ee and breaking out of the gadget box
Open social 2.0 sandbox  ee and breaking out of the gadget boxOpen social 2.0 sandbox  ee and breaking out of the gadget box
Open social 2.0 sandbox ee and breaking out of the gadget box
Ryan Baxter
 
OpenSocial Intro
OpenSocial IntroOpenSocial Intro
OpenSocial Intro
Pamela Fox
 
David Wei And Changhao Jiang Presentation
David Wei And Changhao Jiang PresentationDavid Wei And Changhao Jiang Presentation
David Wei And Changhao Jiang Presentation
Ajax Experience 2009
 

Similaire à Microsoft and jQuery: A true love story - templating and other contributions (20)

Microsoft and jQuery
Microsoft and jQueryMicrosoft and jQuery
Microsoft and jQuery
 
Gadgets Intro (Plus Mapplets)
Gadgets Intro (Plus Mapplets)Gadgets Intro (Plus Mapplets)
Gadgets Intro (Plus Mapplets)
 
Building Smart Workflows - Dan Diebolt
Building Smart Workflows - Dan DieboltBuilding Smart Workflows - Dan Diebolt
Building Smart Workflows - Dan Diebolt
 
Open social 2.0 sandbox ee and breaking out of the gadget box
Open social 2.0 sandbox  ee and breaking out of the gadget boxOpen social 2.0 sandbox  ee and breaking out of the gadget box
Open social 2.0 sandbox ee and breaking out of the gadget box
 
OpenSocial Intro
OpenSocial IntroOpenSocial Intro
OpenSocial Intro
 
Real-World AJAX with ASP.NET
Real-World AJAX with ASP.NETReal-World AJAX with ASP.NET
Real-World AJAX with ASP.NET
 
Widgets: Making Your Site Great and Letting Others Help - WordCamp Victoria
Widgets: Making Your Site Great and Letting Others Help - WordCamp VictoriaWidgets: Making Your Site Great and Letting Others Help - WordCamp Victoria
Widgets: Making Your Site Great and Letting Others Help - WordCamp Victoria
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2
 
Building Web Hack Interfaces
Building Web Hack InterfacesBuilding Web Hack Interfaces
Building Web Hack Interfaces
 
JavaScript 2.0 in Dreamweaver CS4
JavaScript 2.0 in Dreamweaver CS4JavaScript 2.0 in Dreamweaver CS4
JavaScript 2.0 in Dreamweaver CS4
 
Intro to jQuery
Intro to jQueryIntro to jQuery
Intro to jQuery
 
Introduction To ASP.NET MVC
Introduction To ASP.NET MVCIntroduction To ASP.NET MVC
Introduction To ASP.NET MVC
 
David Wei And Changhao Jiang Presentation
David Wei And Changhao Jiang PresentationDavid Wei And Changhao Jiang Presentation
David Wei And Changhao Jiang Presentation
 
Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2
 
Ajax
AjaxAjax
Ajax
 
Introduction to JQuery
Introduction to JQueryIntroduction to JQuery
Introduction to JQuery
 
jQuery and_drupal
jQuery and_drupaljQuery and_drupal
jQuery and_drupal
 

Dernier

Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Safe Software
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
WSO2
 

Dernier (20)

Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
Biography Of Angeliki Cooney | Senior Vice President Life Sciences | Albany, ...
 
Platformless Horizons for Digital Adaptability
Platformless Horizons for Digital AdaptabilityPlatformless Horizons for Digital Adaptability
Platformless Horizons for Digital Adaptability
 
Artificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : UncertaintyArtificial Intelligence Chap.5 : Uncertainty
Artificial Intelligence Chap.5 : Uncertainty
 
Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)Introduction to Multilingual Retrieval Augmented Generation (RAG)
Introduction to Multilingual Retrieval Augmented Generation (RAG)
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers:  A Deep Dive into Serverless Spatial Data and FMECloud Frontiers:  A Deep Dive into Serverless Spatial Data and FME
Cloud Frontiers: A Deep Dive into Serverless Spatial Data and FME
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectors
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
CNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In PakistanCNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In Pakistan
 
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​Elevate Developer Efficiency & build GenAI Application with Amazon Q​
Elevate Developer Efficiency & build GenAI Application with Amazon Q​
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptx
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..
 
WSO2's API Vision: Unifying Control, Empowering Developers
WSO2's API Vision: Unifying Control, Empowering DevelopersWSO2's API Vision: Unifying Control, Empowering Developers
WSO2's API Vision: Unifying Control, Empowering Developers
 
[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf[BuildWithAI] Introduction to Gemini.pdf
[BuildWithAI] Introduction to Gemini.pdf
 
"I see eyes in my soup": How Delivery Hero implemented the safety system for ...
"I see eyes in my soup": How Delivery Hero implemented the safety system for ..."I see eyes in my soup": How Delivery Hero implemented the safety system for ...
"I see eyes in my soup": How Delivery Hero implemented the safety system for ...
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 

Microsoft and jQuery: A true love story - templating and other contributions

  • 1. James Senior - Microsoft Web Evangelist@jsenior - www.jamessenior.com
  • 2.
  • 3. Microsoft & jQuery: A True Love Story
  • 4. A few months ago…
  • 5.
  • 6.
  • 7. Once upon a time… 1997: Classic ASP 1, 2, 3 2002: ASP.NET 1.0 and WebForms Ajax Control Toolkit 2003 to 2007: ASP.NET 1.1, 2, 3, 3.5 2008: Visual Studio 2008 - including jQuery 2008: Official Support for jQuery 2009: ASP.NET MVC – including jQuery 2009: ASP.NET Ajax Library 2009: jQuery on the Microsoft CDN 2010: ASP.NET 4 – including jQuery
  • 8. Visual studio 2010(now with better Javascript support) Demo-tastic
  • 9. Back in February, it was just another day at work
  • 10. ASP.NET Ajax Library Open Source JavaScript Library Cool features, including Script Loader Data-Linking Observer class Templating Data Controls jQuery integration
  • 11. Perfect Match jQuery ASP.NET Ajax Templating Data-Linking Script Loader WCF OData .NET RIA Selectors Plugins Animation
  • 13. All good relationships… Have a clear contribution model Are open, transparent and collaborative Are in the spirit of jQuerycommunity Have specification & Proposals on jQuery Forums Have prototypes as plugins in Github jQuery Core Cool stuff ++ jQuery Core Team ASP.NET Ajax Library Cool Stuff jQuery Plugins Cool stuff Proposal, Specification, Prototype
  • 14. jQueryTemplating 1stcontribution from Microsoft Proposal, Spec and Prototype online http://github.com/jquery/jquery-tmpl
  • 15. The Contribution model in action…
  • 16. What is Templating? Data Templating Engine DOM Template
  • 17. Why client-side templates? Aren’t server side templates good enough? Couldn’t I do this before?
  • 18. What is a Template? vartmpl = "<li>${ dataItem }</li>";
  • 19. What is a Template? <script id=“myTemplate" type="text/html"> <li>${ dataItem }</li> </script>
  • 20. What is a Template? <script id="productsTemplate" type="text/html"> <div> <imgsrc="Content/ProductImages/${Picture}" class="productImage" /> <span class="productName">${Name}</span> Price: ${formatPrice(Price)} <img data-pk="${Id}" src="Content/AddCart.png" alt="Add to Cart" class="addCart" /> </div> </script>
  • 21. .render() <script id=“myTemplate" type="text/html"> <li>${ dataItem }</li> </script> $("#myTemplate") .render( dataObject) .appendTo("ul"); <ul> <li>foo</li> </ul>
  • 22. .render() <script id=“myTemplate" type="text/html"> <li>${ dataItem }</li> </script> $("#myTemplate") .render( arrayOfDataObjects ) .appendTo("ul"); <ul> <li>foo_0</li> <li>foo_1</li> </ul>
  • 24. And then there was more…
  • 25. jQuery Data Linking Sync data and UI
  • 26. jQuery Data Linking Golden Rule - modify data using jQuery
  • 28. Wait a minute… What about the ASP.NET Ajax Library? It’s now RTM quality code Resides in Ajax Control Toolkit (still an open source project) Still served on the CDN We are not actively developing new features
  • 29. This love story is to be continued…
  • 30. More Love: Web Camps Update Free, 2 day events – Learn and Build 3000 people in 12 cities More events being announced after the summer www.webcamps.ms
  • 31. How to find your love Check out the proposals, specs and prototypes Give your feedback to the community Tell a friend about what you heard today Get free tooling http://microsoft.com/web Come along to a Web Camp www.webcamps.ms Slides and demos are on my blog…
  • 32. Contact Me James SeniorMicrosoft Web Evangelist @jsenior james@microsoft.com www.jamessenior.com