SlideShare a Scribd company logo
1 of 18
APRIL 2, 2016
Knockout, TypeScript, and Nested Grids, Oh My!
Data-bound grids without Update Panels
© 2015 Applied Information Sciences, Inc.
Who is this guy?
 Software Engineer at Applied Information Sciences
 Contributing Author: Microsoft SharePoint 2013
Inside Out
 Year 10 of 15-Life with SharePoint
 @SPSamL
 Blog.samlarko.com
 Blog.Appliedis.com
© 2015 Applied Information Sciences, Inc.
Agenda
 Is TypeScript really useful?
 What are MV* Frameworks?
 Why Knockout, not Angular/Durandal/Aurelia?
 Code Walkthrough
> How it works
> Models
> ViewModels
> Views
> Extras (extensions, etc)
 Gotchas/Lessons learned/Facepalm moments
© 2015 Applied Information Sciences, Inc.
TypeScript
 Superset of JavaScript
 Strongly-typed variables
 Visual Studio Intellisense
 OOP
 Still just JavaScript
 ES Feature Implementations:
> Most ES5
> Many ES6
> Some ES7
MV* Frameworks
 MVC
> Controller determines Model
> Model passed to View
> View translates Model for
presentation
> ASP.NET MVC, Angular, Aurelia
 MVVM
> Model and View are same as MVC
> VM provide data-binding between
Model and View, handles UI
actions
> Does not need to reference View
> Silverlight, Knockout, UWP apps
© 2015 Applied Information Sciences, Inc.
Momma said Knock[you]out
 JS Library
 Features
> 2-way Data-binding
> HTML Templating
 Angular/etc are frameworks with full app features
> Routing, dependency injection, scopes, services
 Knockout in SharePoint
> Already have navigation/routing
> SharePoint JSOM or REST for services
© 2015 Applied Information Sciences, Inc.
Knockout Observables
Observable
Observable Array
Computed Observable
KO Utilities
© 2015 Applied Information Sciences, Inc.
Knockout Markup
Events
Data
Containerless binding
Attributes
© 2015 Applied Information Sciences, Inc.
Knockout Extensibility
© 2015 Applied Information Sciences, Inc.
Nested Grids – Original Project
 Project had parent-child data that needed to be displayed in single page
> Search, filter, sort, paging
> Add & edit modals
 Content Types determined relationships
 No inline editing
© 2015 Applied Information Sciences, Inc.
Nested Grid Demo
 Added inline editing
> Allows multiple edits simultaneously
 Knockout HTML templates
© 2015 Applied Information Sciences, Inc.
Lessons Learned/Gotchas
Questions
Resources
 Scot Hillier post on Promises & JSOM -
http://www.shillier.com/archive/2013/03/04/using-promises-with-the-
javascript-client-object-model-in-sharepoint-2013.aspx
 TypeScript - http://www.typescriptlang.com
 KnockoutJS - http://learn.knockoutjs.com/
 DefinitelyTyped TS Definitions - http://definitelytyped.org/
 Simple KO Grid example - http://jsfiddle.net/brettwgreen/zfxmac7z/
 Rob Niemeyer - http://www.knockmeout.net/
Thank you to our Sponsors!
STAY FOR THE RAFFLE,
JOIN US FOR SHAREPINT!
Deol Sports Bar & Grill
6851 Chase Hill Boulevard
San Antonio, TX 78249

More Related Content

What's hot

Migrating to HTML5, Migrating Silverlight to HTML5, Migration Applications t...
Migrating to HTML5,  Migrating Silverlight to HTML5, Migration Applications t...Migrating to HTML5,  Migrating Silverlight to HTML5, Migration Applications t...
Migrating to HTML5, Migrating Silverlight to HTML5, Migration Applications t...Idexcel Technologies
 
apidays LIVE India - The link between technical documentation and developer e...
apidays LIVE India - The link between technical documentation and developer e...apidays LIVE India - The link between technical documentation and developer e...
apidays LIVE India - The link between technical documentation and developer e...apidays
 
Sean Higgins Resume
Sean Higgins ResumeSean Higgins Resume
Sean Higgins ResumeSean Higgins
 
Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...
Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...
Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...Massimo Bonanni
 
Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...
Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...
Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...Edureka!
 
Angular resolver tutorial
Angular resolver tutorialAngular resolver tutorial
Angular resolver tutorialKaty Slemon
 
How to Build Dynamic Forms in Angular Directive with a Backend
How to Build Dynamic Forms in Angular Directive with a BackendHow to Build Dynamic Forms in Angular Directive with a Backend
How to Build Dynamic Forms in Angular Directive with a BackendBackand Cohen
 

What's hot (7)

Migrating to HTML5, Migrating Silverlight to HTML5, Migration Applications t...
Migrating to HTML5,  Migrating Silverlight to HTML5, Migration Applications t...Migrating to HTML5,  Migrating Silverlight to HTML5, Migration Applications t...
Migrating to HTML5, Migrating Silverlight to HTML5, Migration Applications t...
 
apidays LIVE India - The link between technical documentation and developer e...
apidays LIVE India - The link between technical documentation and developer e...apidays LIVE India - The link between technical documentation and developer e...
apidays LIVE India - The link between technical documentation and developer e...
 
Sean Higgins Resume
Sean Higgins ResumeSean Higgins Resume
Sean Higgins Resume
 
Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...
Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...
Tutto quello che avreste voluto sapere sull'API Management (e non avete mai o...
 
Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...
Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...
Spring Boot Tutorial | Microservices Spring Boot | Microservices Architecture...
 
Angular resolver tutorial
Angular resolver tutorialAngular resolver tutorial
Angular resolver tutorial
 
How to Build Dynamic Forms in Angular Directive with a Backend
How to Build Dynamic Forms in Angular Directive with a BackendHow to Build Dynamic Forms in Angular Directive with a Backend
How to Build Dynamic Forms in Angular Directive with a Backend
 

Viewers also liked

Report IV Theoretical Bases of nursing
Report IV Theoretical Bases of nursingReport IV Theoretical Bases of nursing
Report IV Theoretical Bases of nursingMay Vallerie Sarmiento
 
Open Data and Open Government at the local level: an example and thoughts fro...
Open Data and Open Government at the local level: an example and thoughts fro...Open Data and Open Government at the local level: an example and thoughts fro...
Open Data and Open Government at the local level: an example and thoughts fro...Marco Fioretti
 
Latin America meets China - A lookback at key Sino-LATAM transactions
Latin America meets China - A lookback at key Sino-LATAM transactionsLatin America meets China - A lookback at key Sino-LATAM transactions
Latin America meets China - A lookback at key Sino-LATAM transactionsBautista Vermal Azcona
 
Subcultura urbana de lolitas
Subcultura urbana de lolitasSubcultura urbana de lolitas
Subcultura urbana de lolitasoitodivinos
 
Annual State of Service Report
Annual State of Service ReportAnnual State of Service Report
Annual State of Service Reportvavila3
 
Lecture:Organic/Bio waste Life Cycle Assessment case studies
Lecture:Organic/Bio waste Life Cycle Assessment case studiesLecture:Organic/Bio waste Life Cycle Assessment case studies
Lecture:Organic/Bio waste Life Cycle Assessment case studiesDaniel Sandars
 
Industrias del neumático
Industrias del neumáticoIndustrias del neumático
Industrias del neumáticokathyescar
 
El cine mexicano de 1920 a 1940
El cine mexicano de 1920 a 1940El cine mexicano de 1920 a 1940
El cine mexicano de 1920 a 1940kikapu8
 
арт.гімнастика л.м.патенко
арт.гімнастика л.м.патенкоарт.гімнастика л.м.патенко
арт.гімнастика л.м.патенкоNatalyVeremieva
 
042 proreutov 1-8 v5
042 proreutov 1-8 v5042 proreutov 1-8 v5
042 proreutov 1-8 v5proreutov
 

Viewers also liked (16)

Report IV Theoretical Bases of nursing
Report IV Theoretical Bases of nursingReport IV Theoretical Bases of nursing
Report IV Theoretical Bases of nursing
 
3 d workflow
3 d workflow3 d workflow
3 d workflow
 
Ángulos
ÁngulosÁngulos
Ángulos
 
Open Data and Open Government at the local level: an example and thoughts fro...
Open Data and Open Government at the local level: an example and thoughts fro...Open Data and Open Government at the local level: an example and thoughts fro...
Open Data and Open Government at the local level: an example and thoughts fro...
 
Maklab BIN@sheffield
Maklab BIN@sheffieldMaklab BIN@sheffield
Maklab BIN@sheffield
 
Updated Resume
Updated ResumeUpdated Resume
Updated Resume
 
8 generaciones
8 generaciones 8 generaciones
8 generaciones
 
Latin America meets China - A lookback at key Sino-LATAM transactions
Latin America meets China - A lookback at key Sino-LATAM transactionsLatin America meets China - A lookback at key Sino-LATAM transactions
Latin America meets China - A lookback at key Sino-LATAM transactions
 
Subcultura urbana de lolitas
Subcultura urbana de lolitasSubcultura urbana de lolitas
Subcultura urbana de lolitas
 
Annual State of Service Report
Annual State of Service ReportAnnual State of Service Report
Annual State of Service Report
 
Lecture:Organic/Bio waste Life Cycle Assessment case studies
Lecture:Organic/Bio waste Life Cycle Assessment case studiesLecture:Organic/Bio waste Life Cycle Assessment case studies
Lecture:Organic/Bio waste Life Cycle Assessment case studies
 
Industrias del neumático
Industrias del neumáticoIndustrias del neumático
Industrias del neumático
 
El cine mexicano de 1920 a 1940
El cine mexicano de 1920 a 1940El cine mexicano de 1920 a 1940
El cine mexicano de 1920 a 1940
 
Dhananjay Sobale
Dhananjay SobaleDhananjay Sobale
Dhananjay Sobale
 
арт.гімнастика л.м.патенко
арт.гімнастика л.м.патенкоарт.гімнастика л.м.патенко
арт.гімнастика л.м.патенко
 
042 proreutov 1-8 v5
042 proreutov 1-8 v5042 proreutov 1-8 v5
042 proreutov 1-8 v5
 

Similar to Knockout, TypeScript, and Nested Grids, Oh My!

Rajesh Uriti_7years_Sitecore_FrontEnd
Rajesh Uriti_7years_Sitecore_FrontEndRajesh Uriti_7years_Sitecore_FrontEnd
Rajesh Uriti_7years_Sitecore_FrontEndRajesh Uriti
 
Smart Client Software Factory 2010
Smart Client Software Factory  2010Smart Client Software Factory  2010
Smart Client Software Factory 2010Tomy Ismail
 
Angularjs y Simple Page Applications
Angularjs y Simple Page Applications Angularjs y Simple Page Applications
Angularjs y Simple Page Applications johnpisg
 
Angular interview questions
Angular interview questionsAngular interview questions
Angular interview questionsGoa App
 
What’s new in VS 2015 and ALM 2015
What’s new in VS 2015 and ALM 2015What’s new in VS 2015 and ALM 2015
What’s new in VS 2015 and ALM 2015SSW
 
DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation
DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation
DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation Gene Kim
 
Richard ward2016
Richard ward2016Richard ward2016
Richard ward2016Rich Ward
 
Actively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net DeveloperActively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net DeveloperKarthik Reddy
 
Actively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net DeveloperActively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net DeveloperKarthik Reddy
 
IRJET- MVC Framework: A Modern Web Application Development Approach and Working
IRJET- MVC Framework: A Modern Web Application Development Approach and WorkingIRJET- MVC Framework: A Modern Web Application Development Approach and Working
IRJET- MVC Framework: A Modern Web Application Development Approach and WorkingIRJET Journal
 

Similar to Knockout, TypeScript, and Nested Grids, Oh My! (20)

malliCV
malliCVmalliCV
malliCV
 
Rajesh Uriti_7years_Sitecore_FrontEnd
Rajesh Uriti_7years_Sitecore_FrontEndRajesh Uriti_7years_Sitecore_FrontEnd
Rajesh Uriti_7years_Sitecore_FrontEnd
 
Cv vipin
Cv vipinCv vipin
Cv vipin
 
W8/WP8 App Dev for SAP, Part 2: Microsoft OData Application Development
W8/WP8 App Dev for SAP, Part 2: Microsoft OData Application DevelopmentW8/WP8 App Dev for SAP, Part 2: Microsoft OData Application Development
W8/WP8 App Dev for SAP, Part 2: Microsoft OData Application Development
 
Smart Client Software Factory 2010
Smart Client Software Factory  2010Smart Client Software Factory  2010
Smart Client Software Factory 2010
 
Karthikeyan_Resume
Karthikeyan_ResumeKarthikeyan_Resume
Karthikeyan_Resume
 
Ramesh Elangovan
Ramesh ElangovanRamesh Elangovan
Ramesh Elangovan
 
Angularjs y Simple Page Applications
Angularjs y Simple Page Applications Angularjs y Simple Page Applications
Angularjs y Simple Page Applications
 
Angular interview questions
Angular interview questionsAngular interview questions
Angular interview questions
 
What’s new in VS 2015 and ALM 2015
What’s new in VS 2015 and ALM 2015What’s new in VS 2015 and ALM 2015
What’s new in VS 2015 and ALM 2015
 
DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation
DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation
DOES15 - Sherry Chang - Intel’s Journey to Large Scale DevOps Transformation
 
Asp.net mvc
Asp.net mvcAsp.net mvc
Asp.net mvc
 
CV-Suresh
CV-SureshCV-Suresh
CV-Suresh
 
Arun Kumar(7.8Yrs).DOC
Arun Kumar(7.8Yrs).DOCArun Kumar(7.8Yrs).DOC
Arun Kumar(7.8Yrs).DOC
 
Richard ward2016
Richard ward2016Richard ward2016
Richard ward2016
 
Srikanth.Mulesoft
Srikanth.MulesoftSrikanth.Mulesoft
Srikanth.Mulesoft
 
Actively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net DeveloperActively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net Developer
 
Actively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net DeveloperActively looking for an opportunity to work as a challenging Dot Net Developer
Actively looking for an opportunity to work as a challenging Dot Net Developer
 
IRJET- MVC Framework: A Modern Web Application Development Approach and Working
IRJET- MVC Framework: A Modern Web Application Development Approach and WorkingIRJET- MVC Framework: A Modern Web Application Development Approach and Working
IRJET- MVC Framework: A Modern Web Application Development Approach and Working
 
Oracle mobile cloud service
Oracle mobile cloud serviceOracle mobile cloud service
Oracle mobile cloud service
 

Recently uploaded

Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Steffen Staab
 
Diamond Application Development Crafting Solutions with Precision
Diamond Application Development Crafting Solutions with PrecisionDiamond Application Development Crafting Solutions with Precision
Diamond Application Development Crafting Solutions with PrecisionSolGuruz
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...MyIntelliSource, Inc.
 
HR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comHR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comFatema Valibhai
 
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️anilsa9823
 
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female serviceanilsa9823
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Modelsaagamshah0812
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...Health
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsJhone kinadey
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsAndolasoft Inc
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfkalichargn70th171
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVshikhaohhpro
 
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️Delhi Call girls
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfkalichargn70th171
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...panagenda
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxComplianceQuest1
 
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...OnePlan Solutions
 
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...MyIntelliSource, Inc.
 

Recently uploaded (20)

Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
Shapes for Sharing between Graph Data Spaces - and Epistemic Querying of RDF-...
 
Diamond Application Development Crafting Solutions with Precision
Diamond Application Development Crafting Solutions with PrecisionDiamond Application Development Crafting Solutions with Precision
Diamond Application Development Crafting Solutions with Precision
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
 
HR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.comHR Software Buyers Guide in 2024 - HRSoftware.com
HR Software Buyers Guide in 2024 - HRSoftware.com
 
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online  ☂️
CALL ON ➥8923113531 🔝Call Girls Kakori Lucknow best sexual service Online ☂️
 
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female serviceCALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
CALL ON ➥8923113531 🔝Call Girls Badshah Nagar Lucknow best Female service
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Models
 
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICECHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial Goals
 
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS LiveVip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.js
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTV
 
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docx
 
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
 
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
 

Knockout, TypeScript, and Nested Grids, Oh My!

  • 2. Knockout, TypeScript, and Nested Grids, Oh My! Data-bound grids without Update Panels
  • 3. © 2015 Applied Information Sciences, Inc. Who is this guy?  Software Engineer at Applied Information Sciences  Contributing Author: Microsoft SharePoint 2013 Inside Out  Year 10 of 15-Life with SharePoint  @SPSamL  Blog.samlarko.com  Blog.Appliedis.com
  • 4. © 2015 Applied Information Sciences, Inc. Agenda  Is TypeScript really useful?  What are MV* Frameworks?  Why Knockout, not Angular/Durandal/Aurelia?  Code Walkthrough > How it works > Models > ViewModels > Views > Extras (extensions, etc)  Gotchas/Lessons learned/Facepalm moments
  • 5. © 2015 Applied Information Sciences, Inc. TypeScript  Superset of JavaScript  Strongly-typed variables  Visual Studio Intellisense  OOP  Still just JavaScript  ES Feature Implementations: > Most ES5 > Many ES6 > Some ES7
  • 6. MV* Frameworks  MVC > Controller determines Model > Model passed to View > View translates Model for presentation > ASP.NET MVC, Angular, Aurelia  MVVM > Model and View are same as MVC > VM provide data-binding between Model and View, handles UI actions > Does not need to reference View > Silverlight, Knockout, UWP apps
  • 7. © 2015 Applied Information Sciences, Inc. Momma said Knock[you]out  JS Library  Features > 2-way Data-binding > HTML Templating  Angular/etc are frameworks with full app features > Routing, dependency injection, scopes, services  Knockout in SharePoint > Already have navigation/routing > SharePoint JSOM or REST for services
  • 8. © 2015 Applied Information Sciences, Inc. Knockout Observables Observable Observable Array Computed Observable KO Utilities
  • 9. © 2015 Applied Information Sciences, Inc. Knockout Markup Events Data Containerless binding Attributes
  • 10. © 2015 Applied Information Sciences, Inc. Knockout Extensibility
  • 11. © 2015 Applied Information Sciences, Inc. Nested Grids – Original Project  Project had parent-child data that needed to be displayed in single page > Search, filter, sort, paging > Add & edit modals  Content Types determined relationships  No inline editing
  • 12. © 2015 Applied Information Sciences, Inc. Nested Grid Demo  Added inline editing > Allows multiple edits simultaneously  Knockout HTML templates
  • 13.
  • 14. © 2015 Applied Information Sciences, Inc. Lessons Learned/Gotchas
  • 16. Resources  Scot Hillier post on Promises & JSOM - http://www.shillier.com/archive/2013/03/04/using-promises-with-the- javascript-client-object-model-in-sharepoint-2013.aspx  TypeScript - http://www.typescriptlang.com  KnockoutJS - http://learn.knockoutjs.com/  DefinitelyTyped TS Definitions - http://definitelytyped.org/  Simple KO Grid example - http://jsfiddle.net/brettwgreen/zfxmac7z/  Rob Niemeyer - http://www.knockmeout.net/
  • 17. Thank you to our Sponsors!
  • 18. STAY FOR THE RAFFLE, JOIN US FOR SHAREPINT! Deol Sports Bar & Grill 6851 Chase Hill Boulevard San Antonio, TX 78249

Editor's Notes

  1. - I’ll have these slides up on my blog AIS blog will have a post mirroring this presentation, but with reference to 1st post project
  2. Great for those of us who avoided JS Very C#-y
  3. Declarative binding makes for easy View data binding