SlideShare ist ein Scribd-Unternehmen logo
1 von 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

Weitere ähnliche Inhalte

Was ist angesagt?

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 AngularJSArmin Vieweg
 
AngularJS interview questions
AngularJS interview questionsAngularJS interview questions
AngularJS interview questionsUri Lukach
 
Introduction to AngularJS
Introduction to AngularJSIntroduction to AngularJS
Introduction to AngularJSDavid Parsons
 
Advanced AngularJS Concepts
Advanced AngularJS ConceptsAdvanced AngularJS Concepts
Advanced AngularJS ConceptsKyle Hodgson
 
Angularjs interview questions and answers
Angularjs interview questions and answersAngularjs interview questions and answers
Angularjs interview questions and answersAnil Singh
 
Angular 2 interview questions and answers
Angular 2 interview questions and answersAngular 2 interview questions and answers
Angular 2 interview questions and answersAnil Singh
 
Javascript
JavascriptJavascript
JavascriptIblesoft
 
Angular js getting started
Angular js getting startedAngular js getting started
Angular js getting startedHemant Mali
 
Introduction to AngularJS Framework
Introduction to AngularJS FrameworkIntroduction to AngularJS Framework
Introduction to AngularJS FrameworkRaveendra R
 
Angular.js interview questions
Angular.js interview questionsAngular.js interview questions
Angular.js interview questionscodeandyou forums
 
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 ...Barry Gervin
 
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 GervinBarry Gervin
 
Android training day 1
Android training day 1Android training day 1
Android training day 1Vivek Bhusal
 
AngularJS: Overview & Key Features
AngularJS: Overview & Key FeaturesAngularJS: Overview & Key Features
AngularJS: Overview & Key FeaturesMohamad Al Asmar
 

Was ist angesagt? (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
 

Andere mochten auch

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
 
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 projectAiden Yeh
 
Story to be continued
Story to be continuedStory to be continued
Story to be continuedJohn Pooley
 
Love and trust
Love and trustLove and trust
Love and trustPompidoo
 
True love
True loveTrue love
True loveHelga
 
Love story true love final
Love story true love finalLove story true love final
Love story true love finalDS_Shrewsbury
 
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 LOVERachel Devine
 
The Twelve Beers Of Christmas
The Twelve Beers Of ChristmasThe Twelve Beers Of Christmas
The Twelve Beers Of Christmaswatty
 
The Twelve Days Of Christmas
The Twelve Days Of ChristmasThe Twelve Days Of Christmas
The Twelve Days Of ChristmasDavid 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 Lovecoleman yee
 
TRUE LOVE WAITS
TRUE LOVE WAITSTRUE LOVE WAITS
TRUE LOVE WAITSVan Nagac
 
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 Ziosha *♥*
 
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 BODYSr. Helena Burns
 

Andere mochten auch (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
 

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

Gadgets Intro (Plus Mapplets)
Gadgets Intro (Plus Mapplets)Gadgets Intro (Plus Mapplets)
Gadgets Intro (Plus Mapplets)Pamela Fox
 
Building Smart Workflows - Dan Diebolt
Building Smart Workflows - Dan DieboltBuilding Smart Workflows - Dan Diebolt
Building Smart Workflows - Dan DieboltQuickBase, Inc.
 
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 boxRyan Baxter
 
OpenSocial Intro
OpenSocial IntroOpenSocial Intro
OpenSocial IntroPamela Fox
 
Real-World AJAX with ASP.NET
Real-World AJAX with ASP.NETReal-World AJAX with ASP.NET
Real-World AJAX with ASP.NETgoodfriday
 
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 VictoriaJeff Richards
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2fishwarter
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2fishwarter
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2fishwarter
 
The Django Web Application Framework 2
The Django Web Application Framework 2The Django Web Application Framework 2
The Django Web Application Framework 2fishwarter
 
JavaScript 2.0 in Dreamweaver CS4
JavaScript 2.0 in Dreamweaver CS4JavaScript 2.0 in Dreamweaver CS4
JavaScript 2.0 in Dreamweaver CS4alexsaves
 
Introduction To ASP.NET MVC
Introduction To ASP.NET MVCIntroduction To ASP.NET MVC
Introduction To ASP.NET MVCAlan Dean
 
David Wei And Changhao Jiang Presentation
David Wei And Changhao Jiang PresentationDavid Wei And Changhao Jiang Presentation
David Wei And Changhao Jiang PresentationAjax Experience 2009
 
Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2Javascript: Ajax & DOM Manipulation v1.2
Javascript: Ajax & DOM Manipulation v1.2borkweb
 
jQuery and_drupal
jQuery and_drupaljQuery and_drupal
jQuery and_drupalBlackCatWeb
 

Ähnlich wie 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
 

Kürzlich hochgeladen

TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 
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 WorkerThousandEyes
 
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
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking MenDelhi Call girls
 
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
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
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
 
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
 
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...Neo4j
 
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
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking MenDelhi Call girls
 
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
 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘RTylerCroy
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024The Digital Insurer
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...Martijn de Jong
 
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
 
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
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountPuma Security, LLC
 

Kürzlich hochgeladen (20)

TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 
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
 
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
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
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
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
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
 
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...
 
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...
 
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
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 
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
 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
 
2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...2024: Domino Containers - The Next Step. News from the Domino Container commu...
2024: Domino Containers - The Next Step. News from the Domino Container commu...
 
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
 
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
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path Mount
 

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