SlideShare una empresa de Scribd logo
1 de 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

Más contenido relacionado

La actualidad más candente

La actualidad más candente (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
 

Destacado

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
 

Destacado (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
 

Similar a 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
 

Similar a 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
 

Último

+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
?#DUbAI#??##{{(☎️+971_581248768%)**%*]'#abortion pills for sale in dubai@
 

Último (20)

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
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
Top 10 Most Downloaded Games on Play Store in 2024
Top 10 Most Downloaded Games on Play Store in 2024Top 10 Most Downloaded Games on Play Store in 2024
Top 10 Most Downloaded Games on Play Store in 2024
 
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdfUnderstanding Discord NSFW Servers A Guide for Responsible Users.pdf
Understanding Discord NSFW Servers A Guide for Responsible Users.pdf
 
presentation ICT roal in 21st century education
presentation ICT roal in 21st century educationpresentation ICT roal in 21st century education
presentation ICT roal in 21st century education
 
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
 
Repurposing LNG terminals for Hydrogen Ammonia: Feasibility and Cost Saving
Repurposing LNG terminals for Hydrogen Ammonia: Feasibility and Cost SavingRepurposing LNG terminals for Hydrogen Ammonia: Feasibility and Cost Saving
Repurposing LNG terminals for Hydrogen Ammonia: Feasibility and Cost Saving
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, AdobeApidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
Apidays New York 2024 - Scaling API-first by Ian Reasor and Radu Cotescu, Adobe
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsTop 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
 
Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 

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