SlideShare ist ein Scribd-Unternehmen logo
1 von 32
Downloaden Sie, um offline zu lesen
CLASSHEROESNYC
Cross-platform :
Picking the best option for
your next iOS/Android app
Patrick Nollet (@PatrickNLT)
Lead Mobile Developer
CLASSHEROES
CLASSHEROESNYCCLASSHEROESNYC
CLASSHEROES
CLASSHEROESNYC
Amazing trainers.
No club.
$99/month
Unlimited Membership.
ClassHeroes
CLASSHEROESNYC
CLASSHEROESNYC
ClassHeroes
Browse
the activities
CLASSHEROESNYC
CLASSHEROESNYC
ClassHeroes
Book
It’s unlimited
CLASSHEROESNYC
CLASSHEROESNYC
Cross-platform :
Picking the best option for your next iOS/Android app
1. What do you mean by 'cross-platform'?
2. Pros and cons of a cross-platform
solution
3. Available cross-platform options
4. Our approach at ClassHeroes
CLASSHEROESNYC
What do you mean by
'cross-platform'? 🤔
CLASSHEROESNYC
From native to cross-platform
CLASSHEROESNYC
From native to cross-platform
CLASSHEROESNYC
From native to cross-platform
Solution : Share a common cross-platform code base
Small library Whole app
CLASSHEROESNYC
Pros and cons of a
cross-platform solution 👍👎
CLASSHEROESNYC
Pros 👍
DRY (Don't Repeat Yourself)
Synchronization between teams
Synchronized releases
No need to update the app (JS)
CLASSHEROESNYC
Cons 👎
Hard to match native look & feel
Still need iOS and Android experts
Third-party tool
One more layer
Performance
CLASSHEROESNYC
Available options ⚙
CLASSHEROESNYC
Xamarin
All-in-one
Shared app logic
Shared UI thanks to Xamarin.Forms (optional)
C#
Nice and mature language
Native performance
Hard to find experienced developers
CLASSHEROESNYC
Cordova / PhoneGap / Ionic
JavaScript frameworks
Mostly Web Apps with access to native APIs
Targeted at web developers
Limitations:
Performance
UI
CLASSHEROESNYC
React Native
JavaScript
Same design as React
"Learn once, write anywhere"
Native UI components
Hot Reloading
CLASSHEROESNYC
Other approach:
only share App logic
CLASSHEROESNYC
C++
Most common option
iOS: Objective-C++
Android: JNI
Djinni: interfacing with Java and Objective-C
Bjarne Stroustrup
CLASSHEROESNYC
J2ObjC
Java to Objective-C translator
Developed by Google
Native performance
Small project, rough edges
CLASSHEROESNYC
Go Mobile
Go: popular language among backend developers
Experimental
Go ❤ Java & Objective-C
CLASSHEROESNYC
Our approach
CLASSHEROESNYC
Our app
Thin layer above the API
UI at the core
Team of native mobile developers
App Logic
10 %
UI
90 %
Not a good candidate for a cross-
platform approach 😞
CLASSHEROESNYC
Is that it?
CLASSHEROESNYC
We can do more 💪
Cross-platform : Keep platforms in sync
Our case: iOS, Android, Web, Back office
Solution: Exhaustive API specs
Swagger format
CLASSHEROESNYC
Swagger
Swagger Spec
CLASSHEROESNYC
Swagger UI
CLASSHEROESNYC
Mocking server
Generates fake data from Swagger spec
💡backend integration tests
We use the swagger-mock-api middleware (uses Chance.js)
CLASSHEROESNYC
ActionScript
Ada
Apex
Bash
C# (.net 2.0, 4.0 or later)
C++ (cpprest, Qt5, Tizen)
Clojure
Dart
Elixir
Eiffel
Go
Groovy
Haskell (http-client, Servant)
Java (Jersey1.x, Jersey2.x, OkHttp, Retrofit1.x,
Retrofit2.x, Feign, RestTemplate, RESTEasy, Vertx)
Kotlin
Lua
Node.js (ES5, ES6)
Objective-C
Perl
PHP
PowerShell
Python
R
Ruby
Rust
Scala (akka, http4s, swagger-async-httpclient)
Swift (2.x, 3.x, 4.x)
Typescript (Angular1.x, Angular2.x, jQuery)
Client API code generation
swagger-codegen
Dozens of templates
Android: Retrofit, RxJava…
iOS: Objective-C, Swift…
Alternative: SwagGen (Swift)
CLASSHEROESNYC
What did we learn?
Specs are helpful
Global thinking about your product
Big velocity gains:
Independent implementation and tests
Focus on what's important
Monorepo
CLASSHEROESNYC
In a nutshell
Shared app logic vs UI
⚠ cross-platform may not be the best fit!
In any case, consider using specs
CLASSHEROESNYC
The End
@PatrickNLT
Blog post: http://patrick.nollet.org

Weitere ähnliche Inhalte

Ähnlich wie Cross-platform : Picking the best option for your next iOS/Android app

SharePoint Conference North America - Converting your JavaScript to SPFX
SharePoint Conference North America - Converting your JavaScript to SPFXSharePoint Conference North America - Converting your JavaScript to SPFX
SharePoint Conference North America - Converting your JavaScript to SPFX
Mark Rackley
 
DaveParizekResumeJune2015
DaveParizekResumeJune2015DaveParizekResumeJune2015
DaveParizekResumeJune2015
Dave Parizek
 
Anup_Resume_Update_9_1_16
Anup_Resume_Update_9_1_16Anup_Resume_Update_9_1_16
Anup_Resume_Update_9_1_16
Anup Tyagi
 
Best Practices for Cross-Platform Native Applications
Best Practices for Cross-Platform Native ApplicationsBest Practices for Cross-Platform Native Applications
Best Practices for Cross-Platform Native Applications
Kevin Whinnery
 
Mobile app development
Mobile app developmentMobile app development
Mobile app development
EhsanMalik17
 
JAVA Developer_Resume_Vaibhav Srivastav
JAVA Developer_Resume_Vaibhav SrivastavJAVA Developer_Resume_Vaibhav Srivastav
JAVA Developer_Resume_Vaibhav Srivastav
Vaibhav Srivastav
 

Ähnlich wie Cross-platform : Picking the best option for your next iOS/Android app (20)

NativeScript Developer Day Keynote - Todd Anglin & Burke Holland
NativeScript Developer Day Keynote - Todd Anglin & Burke HollandNativeScript Developer Day Keynote - Todd Anglin & Burke Holland
NativeScript Developer Day Keynote - Todd Anglin & Burke Holland
 
[2015/2016] Mobile thinking
[2015/2016] Mobile thinking[2015/2016] Mobile thinking
[2015/2016] Mobile thinking
 
Step by Step Guide on Essay Format in APA For Beginners
Step by Step Guide on Essay Format in APA For BeginnersStep by Step Guide on Essay Format in APA For Beginners
Step by Step Guide on Essay Format in APA For Beginners
 
Progamming Path.pptx
Progamming Path.pptxProgamming Path.pptx
Progamming Path.pptx
 
JavaScript Revolution - 5/Nov/13 - PrDC Saskatoon, SK
JavaScript Revolution - 5/Nov/13 - PrDC Saskatoon, SKJavaScript Revolution - 5/Nov/13 - PrDC Saskatoon, SK
JavaScript Revolution - 5/Nov/13 - PrDC Saskatoon, SK
 
Angular js mobile jsday 2014 - Verona 14 may
Angular js mobile   jsday 2014 - Verona 14 mayAngular js mobile   jsday 2014 - Verona 14 may
Angular js mobile jsday 2014 - Verona 14 may
 
SharePoint Conference North America - Converting your JavaScript to SPFX
SharePoint Conference North America - Converting your JavaScript to SPFXSharePoint Conference North America - Converting your JavaScript to SPFX
SharePoint Conference North America - Converting your JavaScript to SPFX
 
Mobile Delivery Run Through
Mobile Delivery Run ThroughMobile Delivery Run Through
Mobile Delivery Run Through
 
Groovy And Grails
Groovy And GrailsGroovy And Grails
Groovy And Grails
 
DaveParizekResumeJune2015
DaveParizekResumeJune2015DaveParizekResumeJune2015
DaveParizekResumeJune2015
 
Anup_Resume_Update_9_1_16
Anup_Resume_Update_9_1_16Anup_Resume_Update_9_1_16
Anup_Resume_Update_9_1_16
 
Best Practices for Cross-Platform Native Applications
Best Practices for Cross-Platform Native ApplicationsBest Practices for Cross-Platform Native Applications
Best Practices for Cross-Platform Native Applications
 
9 reasons why programmers should learn react native
9 reasons why programmers should learn react native9 reasons why programmers should learn react native
9 reasons why programmers should learn react native
 
Mobile app development
Mobile app developmentMobile app development
Mobile app development
 
Website development tools
Website development toolsWebsite development tools
Website development tools
 
CommonJS via PINF JavaScript Loader - Introduction
CommonJS via PINF JavaScript Loader - IntroductionCommonJS via PINF JavaScript Loader - Introduction
CommonJS via PINF JavaScript Loader - Introduction
 
JAVA Developer_Resume_Vaibhav Srivastav
JAVA Developer_Resume_Vaibhav SrivastavJAVA Developer_Resume_Vaibhav Srivastav
JAVA Developer_Resume_Vaibhav Srivastav
 
Mobile application development platform
Mobile application development platformMobile application development platform
Mobile application development platform
 
JavaScript - The Universal Platform?
JavaScript - The Universal Platform?JavaScript - The Universal Platform?
JavaScript - The Universal Platform?
 
Top 8 Alternatives Of Xamarin.pdf
Top 8 Alternatives Of Xamarin.pdfTop 8 Alternatives Of Xamarin.pdf
Top 8 Alternatives Of Xamarin.pdf
 

Kürzlich hochgeladen

AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM TechniquesAI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
VictorSzoltysek
 
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdfintroduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
VishalKumarJha10
 
+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
 

Kürzlich hochgeladen (20)

AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM TechniquesAI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
 
Introducing Microsoft’s new Enterprise Work Management (EWM) Solution
Introducing Microsoft’s new Enterprise Work Management (EWM) SolutionIntroducing Microsoft’s new Enterprise Work Management (EWM) Solution
Introducing Microsoft’s new Enterprise Work Management (EWM) Solution
 
The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...
The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...
The Guide to Integrating Generative AI into Unified Continuous Testing Platfo...
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
 
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
Reassessing the Bedrock of Clinical Function Models: An Examination of Large ...
 
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-...
 
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdfintroduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.pdf
introduction-to-automotive Andoid os-csimmonds-ndctechtown-2021.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...
 
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
 
8257 interfacing 2 in microprocessor for btech students
8257 interfacing 2 in microprocessor for btech students8257 interfacing 2 in microprocessor for btech students
8257 interfacing 2 in microprocessor for btech students
 
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 ...
 
VTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learnVTU technical seminar 8Th Sem on Scikit-learn
VTU technical seminar 8Th Sem on Scikit-learn
 
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
 
10 Trends Likely to Shape Enterprise Technology in 2024
10 Trends Likely to Shape Enterprise Technology in 202410 Trends Likely to Shape Enterprise Technology in 2024
10 Trends Likely to Shape Enterprise Technology in 2024
 
Azure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdf
Azure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdfAzure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdf
Azure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdf
 
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
 
+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...
 
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
 
Define the academic and professional writing..pdf
Define the academic and professional writing..pdfDefine the academic and professional writing..pdf
Define the academic and professional writing..pdf
 
AI & Machine Learning Presentation Template
AI & Machine Learning Presentation TemplateAI & Machine Learning Presentation Template
AI & Machine Learning Presentation Template
 

Cross-platform : Picking the best option for your next iOS/Android app