SlideShare una empresa de Scribd logo
1 de 76
iPhone and Ruby on Rails
Web Development for the iPhone is still relevant.
Agenda
Safari Browser
iPhone Web-App Development Overview
Ruby on Rails Demo
Finish-up
Hi, I’m Andy
Hi, I’m Andy
I’m an iPhone Developer
Hi, I’m Andy
I’m an iPhone Developer
Hi, I’m Andy
I’m an iPhone Developer



Ninth Division
Hi, I’m Andy
I’m an iPhone Developer



Ninth Division
Build applications one the Apple Platforms.
Safari
Web Browser
Desktop and Mobile
Desktop and Mobile
Browsers Evolved
Browser History
Konqueror Timeline
Konqueror Timeline
Version 1                     Version 2
  1996
                         October 23, 2000
                                            Version 4
                                              2008




            Switch to KHTML
Webkit Timeline
www.webkit.org
Webkit Timeline
 www.webkit.org


                                                        New Javascript Engine
                                                             June 2, 2008
Begin work       Safari first adaption
   2002              October 23, 2000

                                        Open Source
                                         June 7, 2005




                                                                      HTML 5
              Email to KDE                              Move from    Nov 2007
             mailing list from                           KTHML
                  Apple                                    to
                                                         Webkit
                                                        Dec. 2005
Safari Timeline
Safari Timeline
Version 1
  2003
                       Version 2
                          2005



                                           Version 3
                                              2007                    Version 4
                                                                        2009




   Steve Announces                 Mac OSX 10.4                           Mac OSX 10.6
                      Mac OSX                          Mac OSX 10.5
                     10.2 & 10.3
Safari Browser Features
                          Mobile              Desktop
     AJAX
    HTML 5
     CSS 3
 Offline Storage
Developer Tools *
 Effects / Media

                    * different per browser
Safari Browser Features
                          Mobile              Desktop
     AJAX
    HTML 5
     CSS 3
 Offline Storage
Developer Tools *
 Effects / Media

                    * different per browser
Safari Browser Features
                          Mobile              Desktop
     AJAX
    HTML 5
     CSS 3
 Offline Storage
Developer Tools *
 Effects / Media

                    * different per browser
Developer Tools
Developer Tools
Developer Tools
Developer Tools (2)
Developer Tools (2)
Developer Tools (2)
Developer Tools (2)
CSS
CSS
CSS
CSS
CSS
CSS
CSS
Want more CSS Recipes?
Then Go Here
Excitement
                         Safari Mobile

   Location Aware

 Better Offline Storage

     Flash Player

     Copy / Paste
Excitement
                         Safari Mobile

   Location Aware

 Better Offline Storage

     Flash Player

     Copy / Paste
Excitement
                         Safari Mobile

   Location Aware

 Better Offline Storage

     Flash Player

     Copy / Paste
iPhone Web
Development
Design Gotchas
Thumbs - no pointer    In and out of network
                       coverage
Thumbs usually 44x44
pixels                 iPhone / Standard style
                       sheet [ provide both ].
Mouse pointer 12x12
pixels                 App or Webpage?
Less screen size
Design Pointers
 Simplify the interface
 as much as you can.
 Tell user what is
 happening.
 Consistent design
 Interruptions
 Use the phone!
What doesn’t work.
Javascript mouseover, mouseout, :hover and tooltips
onkeydown, onkeypress, onkeyup,
No streaming of files
Files less than 10MB
Javascript must execute in 5 seconds
Safari support GZIP!
Framesets will make your life hell.
General Notes

Optimize
Throw out your Javascript/CSS frameworks.
Load your site in fragments.
I love the iPhone too, but remember there are others.
When you are done optimizing, optimize your site more
Human Interface Guidelines
One of the most important documents as an
iPhone developer - native and web.
Human Interface Guidelines
One of the most important documents as an
iPhone developer - native and web.
Human Interface Guidelines
One of the most important documents as an
iPhone developer - native and web.




                  Download it here later
iPhone SDK Timeline
“All you need is the Web Browser” - Steve
iPhone SDK Timeline
“All you need is the Web Browser” - Steve


iPhone Announced
    Jan. 2007
                                    iPhone SDK
                                     March 2008
                 iPhone Available                    iPhone 2 Public
                      June 2007                           July 2008




          SDK is Webkit                                                Open   First Fart
                                                  Closed Beta                    App
                      Freak out
Safari Mobile Examples

 Weather Underground
 TA-DA List
 Flickr.com
 Twitter.com
Dashcode.app
Honestly, I hate it.
Webkit Embedded
Not going to talk much about this, but just so you
know... you can embed the core of safari in your
native iPhone App.
iUI
http://code.google.com/p/iui/
“We will rock your world when you want to build a
native looking iPhone web application”
CiUI
http://code.google.com/p/ciui-dev/
“We are iUI with a slightly different design”
Tools needed
iPhone SDK
iPhoney
Your iPhone or iPod-Touch
Apple Developer Connection
Let’s all create an account
Safari / iPhone Development Center
Did Andy show you these links?
Ruby on Rails
Code.
No slides for this section. ;-)
Cocoa User Group
Focus on Cocoa and Cocoa-touch
.... but include: Mac, iPhone, iPhone-web, Mac-
web, XCode, Interface Builder, Safari
Open Debate
lets start a flame war.

Más contenido relacionado

La actualidad más candente

Site Development Processes for Small Teams
Site Development Processes for Small TeamsSite Development Processes for Small Teams
Site Development Processes for Small Teams
Jeff Segars
 

La actualidad más candente (11)

Ionic Framework
Ionic FrameworkIonic Framework
Ionic Framework
 
Ionic2 the the journey continues ng-sydney 02-03-16 and ionicaustralia 23-0...
Ionic2   the the journey continues ng-sydney 02-03-16 and ionicaustralia 23-0...Ionic2   the the journey continues ng-sydney 02-03-16 and ionicaustralia 23-0...
Ionic2 the the journey continues ng-sydney 02-03-16 and ionicaustralia 23-0...
 
Workshop Ionic Framework - CC FE & UX
Workshop Ionic Framework - CC FE & UXWorkshop Ionic Framework - CC FE & UX
Workshop Ionic Framework - CC FE & UX
 
Hybrid app development with ionic
Hybrid app development with ionicHybrid app development with ionic
Hybrid app development with ionic
 
Ionic CLI Adventures
Ionic CLI AdventuresIonic CLI Adventures
Ionic CLI Adventures
 
Ionic Mobile Applications - Hybrid Mobile Applications Without Compromises
Ionic Mobile Applications - Hybrid Mobile Applications Without CompromisesIonic Mobile Applications - Hybrid Mobile Applications Without Compromises
Ionic Mobile Applications - Hybrid Mobile Applications Without Compromises
 
Modern Web Application Development Workflow - EclipseCon France 2014
Modern Web Application Development Workflow - EclipseCon France 2014Modern Web Application Development Workflow - EclipseCon France 2014
Modern Web Application Development Workflow - EclipseCon France 2014
 
Ionic Crash Course! Hack-a-ton SF
Ionic Crash Course! Hack-a-ton SFIonic Crash Course! Hack-a-ton SF
Ionic Crash Course! Hack-a-ton SF
 
Site Development Processes for Small Teams
Site Development Processes for Small TeamsSite Development Processes for Small Teams
Site Development Processes for Small Teams
 
React native development with expo
React native development with expoReact native development with expo
React native development with expo
 
Silent push
Silent pushSilent push
Silent push
 

Destacado (7)

iPhone Development Overview
iPhone Development OverviewiPhone Development Overview
iPhone Development Overview
 
DefineLabs Mobile Apps Portfolio
DefineLabs Mobile Apps PortfolioDefineLabs Mobile Apps Portfolio
DefineLabs Mobile Apps Portfolio
 
DefineLabs E Commerce Portfolio
DefineLabs E Commerce PortfolioDefineLabs E Commerce Portfolio
DefineLabs E Commerce Portfolio
 
01 Pia Waugh Gov2 Syd
01 Pia Waugh Gov2 Syd01 Pia Waugh Gov2 Syd
01 Pia Waugh Gov2 Syd
 
JHL Enterprises Presentation
JHL Enterprises PresentationJHL Enterprises Presentation
JHL Enterprises Presentation
 
Intro to iPhone Development
Intro to iPhone DevelopmentIntro to iPhone Development
Intro to iPhone Development
 
iPhone Apps - What, how, why?
iPhone Apps - What, how, why?iPhone Apps - What, how, why?
iPhone Apps - What, how, why?
 

Similar a iPhone Web Development

Christopher Allen's Presentation at eComm 2009
Christopher Allen's Presentation at eComm 2009Christopher Allen's Presentation at eComm 2009
Christopher Allen's Presentation at eComm 2009
eCommConf
 
Widget Workshop Advanced Development
Widget Workshop Advanced DevelopmentWidget Workshop Advanced Development
Widget Workshop Advanced Development
Dominik Helleberg
 
Os Henrikson
Os HenriksonOs Henrikson
Os Henrikson
oscon2007
 
Apple safari
Apple safariApple safari
Apple safari
Belfore
 
Brian Le Roux Presentation Introducing Phone Gap
Brian Le Roux Presentation Introducing Phone GapBrian Le Roux Presentation Introducing Phone Gap
Brian Le Roux Presentation Introducing Phone Gap
Ajax Experience 2009
 

Similar a iPhone Web Development (20)

XTech May 2008
XTech May 2008XTech May 2008
XTech May 2008
 
Web or SDK Development
Web or SDK DevelopmentWeb or SDK Development
Web or SDK Development
 
JavaScript for ABAP Programmers - 1/7 Introduction
JavaScript for ABAP Programmers - 1/7 IntroductionJavaScript for ABAP Programmers - 1/7 Introduction
JavaScript for ABAP Programmers - 1/7 Introduction
 
DDive- Giuseppe Grasso - mobile su Lotus
DDive- Giuseppe Grasso - mobile su LotusDDive- Giuseppe Grasso - mobile su Lotus
DDive- Giuseppe Grasso - mobile su Lotus
 
Christopher Allen's Presentation at eComm 2009
Christopher Allen's Presentation at eComm 2009Christopher Allen's Presentation at eComm 2009
Christopher Allen's Presentation at eComm 2009
 
Developing FirefoxOS
Developing FirefoxOSDeveloping FirefoxOS
Developing FirefoxOS
 
Widget Workshop Advanced Development
Widget Workshop Advanced DevelopmentWidget Workshop Advanced Development
Widget Workshop Advanced Development
 
Javascript State of the Union 2015 - English
Javascript State of the Union 2015 - EnglishJavascript State of the Union 2015 - English
Javascript State of the Union 2015 - English
 
Session 1 - Introduction to iOS 7 and SDK
Session 1 -  Introduction to iOS 7 and SDKSession 1 -  Introduction to iOS 7 and SDK
Session 1 - Introduction to iOS 7 and SDK
 
Os Henrikson
Os HenriksonOs Henrikson
Os Henrikson
 
Don't touch the mobile parts
Don't touch the mobile partsDon't touch the mobile parts
Don't touch the mobile parts
 
HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09
 
Christopher Allen’s Presentation at eComm 2009
Christopher Allen’s Presentation at eComm 2009Christopher Allen’s Presentation at eComm 2009
Christopher Allen’s Presentation at eComm 2009
 
Myths of Angular 2: What Angular Really Is
Myths of Angular 2: What Angular Really IsMyths of Angular 2: What Angular Really Is
Myths of Angular 2: What Angular Really Is
 
Apple safari
Apple safariApple safari
Apple safari
 
WebKit, why it matters (PDF version)
WebKit, why it matters (PDF version)WebKit, why it matters (PDF version)
WebKit, why it matters (PDF version)
 
What plugins are out there?
What plugins are out there?What plugins are out there?
What plugins are out there?
 
State of the Mobile Browsers
State of the Mobile BrowsersState of the Mobile Browsers
State of the Mobile Browsers
 
Brian Le Roux Presentation Introducing Phone Gap
Brian Le Roux Presentation Introducing Phone GapBrian Le Roux Presentation Introducing Phone Gap
Brian Le Roux Presentation Introducing Phone Gap
 
Unify - JSConf.EU 2010
Unify - JSConf.EU 2010Unify - JSConf.EU 2010
Unify - JSConf.EU 2010
 

Último

Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
WSO2
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
panagenda
 
+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)

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
 
Introduction to use of FHIR Documents in ABDM
Introduction to use of FHIR Documents in ABDMIntroduction to use of FHIR Documents in ABDM
Introduction to use of FHIR Documents in ABDM
 
Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..Understanding the FAA Part 107 License ..
Understanding the FAA Part 107 License ..
 
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
Apidays New York 2024 - Passkeys: Developing APIs to enable passwordless auth...
 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
Vector Search -An Introduction in Oracle Database 23ai.pptx
Vector Search -An Introduction in Oracle Database 23ai.pptxVector Search -An Introduction in Oracle Database 23ai.pptx
Vector Search -An Introduction in Oracle Database 23ai.pptx
 
Architecting Cloud Native Applications
Architecting Cloud Native ApplicationsArchitecting Cloud Native Applications
Architecting Cloud Native Applications
 
AI in Action: Real World Use Cases by Anitaraj
AI in Action: Real World Use Cases by AnitarajAI in Action: Real World Use Cases by Anitaraj
AI in Action: Real World Use Cases by Anitaraj
 
Corporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptxCorporate and higher education May webinar.pptx
Corporate and higher education May webinar.pptx
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024FWD Group - Insurer Innovation Award 2024
FWD Group - Insurer Innovation Award 2024
 
CNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In PakistanCNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In Pakistan
 
Exploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with MilvusExploring Multimodal Embeddings with Milvus
Exploring Multimodal Embeddings with Milvus
 
+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...
 
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 AmsterdamDEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
AI+A11Y 11MAY2024 HYDERBAD GAAD 2024 - HelloA11Y (11 May 2024)
AI+A11Y 11MAY2024 HYDERBAD GAAD 2024 - HelloA11Y (11 May 2024)AI+A11Y 11MAY2024 HYDERBAD GAAD 2024 - HelloA11Y (11 May 2024)
AI+A11Y 11MAY2024 HYDERBAD GAAD 2024 - HelloA11Y (11 May 2024)
 
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
 
ICT role in 21st century education and its challenges
ICT role in 21st century education and its challengesICT role in 21st century education and its challenges
ICT role in 21st century education and its challenges
 

iPhone Web Development

Notas del editor

  1. Who’s new to rails? Who’s done a tutorial or two and beggs to use but still uses crappy java? Who has done anything with the iPhone SDK? Who owns an iPhone?
  2. Stuff you should already know.
  3. What do you guys know about Safari? Webkit? KDE? Used on many other browsers?
  4. Webkit is a fork of KHTML, but didn’t start that way. Apple build their own to become webkit. Began work somewhere after KDE 2. WebCore and JavascriptCore are open sourced under GNU
  5. Features that matter to developers and designers So lets talk about some of those features.
  6. Features that matter to developers and designers So lets talk about some of those features.
  7. Flash - we will *never* see it
  8. Flash - we will *never* see it
  9. Happy iPhone is a happy user. - you care about your users right? Design is crucial to a happy user.