SlideShare a Scribd company logo
1 of 62
Download to read offline
CakeFest Orlando 2008




                        With jQuery & CakePHP to


            World Domination

                                                   by Felix Geisendörfer
About me

•   Felix Geisendörfer, 20 years old, Germany


•   Blogger / Programmer / Entrepreneur


•   Used jQuery & CakePHP in all battle fields
    •   School projects, small business sites, 300++ DB table
        monster project
Blog about CakePHP

                     ThinkingPHP.org
Deep inside the CakePHP core

                               ThinkingPHP.org
Deep inside the CakePHP core
Sometimes things just go wrong
                                 ThinkingPHP.org
World Domination
World Domination
World Domination
World Domination
Many empires tried to achieve it
World Domination
        Mauryan Empire                  Persian Empire
Soviet Union                Mongol Empire

                                        Macedonian Empire
      Roman Empire
                                               Nazi Germany
 Ming Empire        Portuguese empire
                                         Arab Caliphate
                  French Empire
 Spanish Empire
                               Habsburg Empire
            Japanese Empire
                                             British Empire
         American Empire
World Domination
        Mauryan Empire                  Persian Empire
Soviet Union
                          & is
                            Mongol Empire

      Roman Empire ut                   Macedonian Empire
                            r
                     N or Caliphate
                   p N Arab
                                               Nazi Germany

                 h Empire
 Ming Empire        Portuguese empire

               P ck
             French
 Spanish Empire
                    u Habsburg Empire
                  hEmpire
               C
         Japanese
                                             British Empire
         American Empire
CakePHP
   &



 jQuery
Quick battle analysis
The problems


• No jQuery JS helper available
• No manual on using jQuery + CakePHP
• No jQuery / CakePHP framework   (except Jamal)
Why jQuery?

• Embraces succinct code
• Huge number of plugins out there
• Plays nice with other libraries
Why CakePHP?


  just kidding ...
Why CakePHP?


 ... well actually
Jaxer: The new guy in town

• Write entire web applications in JavaScript
• MySQL, SQLite, SMTP, File system access
• Server process stays alive
Jaxer: Why not?

• No Linux version yet   Jaxer also works with
                         (Cake)PHP




• Might not scale
• No Framework yet
So let’s take over the world ...
Getting your JS included
 Controller (app/controllers/posts_controller.php)




            The Q
                 uick &
 View (app/views/posts/index.ctp)

                                                 Easy
 Layout (app/views/layouts/default.ctp)
Problems you’ll run into
Not DRY
Not DRY
Confusing

                     wh at
              d o es    ?
         e  e
           r e fro    m
      w h      m
   F,
 T de c      o
W lu
 i nc
How to KISS this?

• Have a central place to define JS includes
• Only one reference to each JS file
• Simple rules for inclusion on a per action
  basis
Rule based JS inclusion
app/config/js_includes.php (custom approach, not in cake core!)
The inclusion rule parser


                   ib le
             Fl ex
        T he

    (Google “33 Lines of Magic Code”)
                                        Will talk about this in tomorrows
                                        talks
Automatic JS inclusion

• If “app/webroot/js/views/layouts/{layout}.js”
  exists -> load it


• If “app/webroot/js/views/{controller}/{view}.js”
  exists -> load it
Getting controller data to JS




  Yummy function for your AppController
Getting controller data to JS




 How to make a list of $posts available in JS
Getting controller data to JS

(put this in your layouts <head> section)




 How to export your $jsonVars array to JavaScript
Getting controller data to JS




   How to access jsonVars in JavaScript
World Domination
PostTask.com

• Personal time management
• Next step: Becoming the best project
  management tool


• After that: World Domination            l Break
                                   e rcia
                             Co mm
jayDom
Microformats on steriods
MVC concept

                   HTML / DOM
 Model



                      CSS
  View


                    JavaScript
Controller
Ask audience

         Microformats                     who has heard
                                          about
                                          Microformat




• A collection of standardized HTML
  snippets


• Can be parsed by spiders, making your site
  semantic in a way thats actually useful


• Examples: hCard, rel-license, adr, geo ...
jayDom Microformats
• Usually non-standardized formats, custom
  to your application


• Can change as your app evolves

• You are already using them
jayDom Microformat Example
jayDom Microformat Example




Task.id              Task.date
jayDom Microformat Example
                   Task.name




Task.progress   Task.time_done   Task.time_total
Microformat I/O

• In order to read data from our
  microformat, we need to parse it


• If we want to update our data we also need
  to be able to write to the microformat
Reading Microformat data
Microformat snippet we are interested in



                        Task.progress
                                           Ask: Anybody who doesn’t
                                           know regex?
How to parse the encoded progress value
Writing Microformat data
Microformat snippet we are interested in




How to encode progress value of “75”
Writing Microformat data
Microformat snippet we are interested in




How to encode progress value of “75”
jayDom way of semantic encoding

Get:

                 ea ts
                B

Set:


                 ea ts
                B
Mapping DOM accessors




Get:


Set:
A real world example
jayDom Microformat Example




Task.id
jayDom Microformat Example




Task.id              Task.date
jayDom Microformat Example




Task.progress
jayDom Microformat Example




Task.progress   Task.time_done
jayDom Microformat Example




Task.progress   Task.time_done   Task.time_total
jayDom Microformat Example
                   Task.name




Task.progress   Task.time_done   Task.time_total
World Domination
jQuery Selectors on steriods
    Select all tasks with the name ‘New Task’




   Select all tasks that are more then half done
jQuery Selectors on steriods


• Find all Posts
• That have at least one Comment written by
  Felix


• Only return posts that visible (not hidden)
Easy Ajax
jayDom Advantages
• Put your semantics to use

• Save tons of bandwidth on server calls
  using JSON


• Hassle-less client server communication
Questions

• Thanks for listening

• Thanks for helping the CakePHP project
  grow



Slides will be available on ThinkingPHP.org shortly!

More Related Content

Viewers also liked (6)

Digital analytics lecture1
Digital analytics lecture1Digital analytics lecture1
Digital analytics lecture1
 
Sociology and science
Sociology and scienceSociology and science
Sociology and science
 
Sociology as a science
Sociology as a scienceSociology as a science
Sociology as a science
 
Is soc a science?
Is soc a science?Is soc a science?
Is soc a science?
 
A2 Sociology & Science
A2 Sociology & ScienceA2 Sociology & Science
A2 Sociology & Science
 
Is Sociology Science?
Is Sociology Science?Is Sociology Science?
Is Sociology Science?
 

Similar to With jQuery & CakePHP to World Domination

Mongo NYC PHP Development
Mongo NYC PHP Development Mongo NYC PHP Development
Mongo NYC PHP Development
Fitz Agard
 
2008-12-21 Rubinius
2008-12-21 Rubinius2008-12-21 Rubinius
2008-12-21 Rubinius
Lin Jen-Shin
 
In Pursuit of the Holy Grail: Building Isomorphic JavaScript Apps
In Pursuit of the Holy Grail: Building Isomorphic JavaScript AppsIn Pursuit of the Holy Grail: Building Isomorphic JavaScript Apps
In Pursuit of the Holy Grail: Building Isomorphic JavaScript Apps
Spike Brehm
 
SPA Architecture Basics - Colombo JS meetup
SPA Architecture Basics - Colombo JS meetupSPA Architecture Basics - Colombo JS meetup
SPA Architecture Basics - Colombo JS meetup
Hasith Yaggahavita
 
Javascript Framework Roundup FYB
Javascript Framework Roundup FYBJavascript Framework Roundup FYB
Javascript Framework Roundup FYB
nukeevry1
 
General Assembly Workshop: Advanced JavaScript
General Assembly Workshop: Advanced JavaScriptGeneral Assembly Workshop: Advanced JavaScript
General Assembly Workshop: Advanced JavaScript
Spike Brehm
 

Similar to With jQuery & CakePHP to World Domination (20)

Jvm tuning in a rush! - Lviv JUG
Jvm tuning in a rush! - Lviv JUGJvm tuning in a rush! - Lviv JUG
Jvm tuning in a rush! - Lviv JUG
 
Java tuning on GNU/Linux for busy dev
Java tuning on GNU/Linux for busy devJava tuning on GNU/Linux for busy dev
Java tuning on GNU/Linux for busy dev
 
Wordpress as a CMS
Wordpress as a CMSWordpress as a CMS
Wordpress as a CMS
 
Mongo NYC PHP Development
Mongo NYC PHP Development Mongo NYC PHP Development
Mongo NYC PHP Development
 
Efficient JavaScript Development
Efficient JavaScript DevelopmentEfficient JavaScript Development
Efficient JavaScript Development
 
When To Use Ruby On Rails
When To Use Ruby On RailsWhen To Use Ruby On Rails
When To Use Ruby On Rails
 
Drupal 6 JavaScript and jQuery
Drupal 6 JavaScript and jQueryDrupal 6 JavaScript and jQuery
Drupal 6 JavaScript and jQuery
 
How the HotSpot and Graal JVMs execute Java Code
How the HotSpot and Graal JVMs execute Java CodeHow the HotSpot and Graal JVMs execute Java Code
How the HotSpot and Graal JVMs execute Java Code
 
Threads Needles Stacks Heaps - Java edition
Threads Needles Stacks Heaps - Java editionThreads Needles Stacks Heaps - Java edition
Threads Needles Stacks Heaps - Java edition
 
Quo vadis, JavaScript? Devday.pl keynote
Quo vadis, JavaScript? Devday.pl keynoteQuo vadis, JavaScript? Devday.pl keynote
Quo vadis, JavaScript? Devday.pl keynote
 
2008-12-21 Rubinius
2008-12-21 Rubinius2008-12-21 Rubinius
2008-12-21 Rubinius
 
Practical Groovy DSL
Practical Groovy DSLPractical Groovy DSL
Practical Groovy DSL
 
Daniel Spiller's Wordpress Presentation
Daniel Spiller's Wordpress PresentationDaniel Spiller's Wordpress Presentation
Daniel Spiller's Wordpress Presentation
 
In Pursuit of the Holy Grail: Building Isomorphic JavaScript Apps
In Pursuit of the Holy Grail: Building Isomorphic JavaScript AppsIn Pursuit of the Holy Grail: Building Isomorphic JavaScript Apps
In Pursuit of the Holy Grail: Building Isomorphic JavaScript Apps
 
Just In Time Scalability Agile Methods To Support Massive Growth Presentation
Just In Time Scalability  Agile Methods To Support Massive Growth PresentationJust In Time Scalability  Agile Methods To Support Massive Growth Presentation
Just In Time Scalability Agile Methods To Support Massive Growth Presentation
 
SPA Architecture Basics - Colombo JS meetup
SPA Architecture Basics - Colombo JS meetupSPA Architecture Basics - Colombo JS meetup
SPA Architecture Basics - Colombo JS meetup
 
Hacking Map API's Workshop - Where2.0 2009
Hacking Map API's Workshop - Where2.0 2009Hacking Map API's Workshop - Where2.0 2009
Hacking Map API's Workshop - Where2.0 2009
 
Where2009 - Hacking Map APIs
Where2009 - Hacking Map APIsWhere2009 - Hacking Map APIs
Where2009 - Hacking Map APIs
 
Javascript Framework Roundup FYB
Javascript Framework Roundup FYBJavascript Framework Roundup FYB
Javascript Framework Roundup FYB
 
General Assembly Workshop: Advanced JavaScript
General Assembly Workshop: Advanced JavaScriptGeneral Assembly Workshop: Advanced JavaScript
General Assembly Workshop: Advanced JavaScript
 

More from Felix Geisendörfer

More from Felix Geisendörfer (17)

Node.js - As a networking tool
Node.js - As a networking toolNode.js - As a networking tool
Node.js - As a networking tool
 
Node.js - Best practices
Node.js  - Best practicesNode.js  - Best practices
Node.js - Best practices
 
Node.js - A practical introduction (v2)
Node.js  - A practical introduction (v2)Node.js  - A practical introduction (v2)
Node.js - A practical introduction (v2)
 
Nodejs a-practical-introduction-oredev
Nodejs a-practical-introduction-oredevNodejs a-practical-introduction-oredev
Nodejs a-practical-introduction-oredev
 
Building an alarm clock with node.js
Building an alarm clock with node.jsBuilding an alarm clock with node.js
Building an alarm clock with node.js
 
How to Test Asynchronous Code (v2)
How to Test Asynchronous Code (v2)How to Test Asynchronous Code (v2)
How to Test Asynchronous Code (v2)
 
How to Test Asynchronous Code
How to Test Asynchronous CodeHow to Test Asynchronous Code
How to Test Asynchronous Code
 
Nodejs - A quick tour (v6)
Nodejs - A quick tour (v6)Nodejs - A quick tour (v6)
Nodejs - A quick tour (v6)
 
Nodejs - A quick tour (v5)
Nodejs - A quick tour (v5)Nodejs - A quick tour (v5)
Nodejs - A quick tour (v5)
 
Nodejs - Should Ruby Developers Care?
Nodejs - Should Ruby Developers Care?Nodejs - Should Ruby Developers Care?
Nodejs - Should Ruby Developers Care?
 
Nodejs - A quick tour (v4)
Nodejs - A quick tour (v4)Nodejs - A quick tour (v4)
Nodejs - A quick tour (v4)
 
Node.js in production
Node.js in productionNode.js in production
Node.js in production
 
Nodejs - A-quick-tour-v3
Nodejs - A-quick-tour-v3Nodejs - A-quick-tour-v3
Nodejs - A-quick-tour-v3
 
Dirty - How simple is your database?
Dirty - How simple is your database?Dirty - How simple is your database?
Dirty - How simple is your database?
 
Node.js - A Quick Tour II
Node.js - A Quick Tour IINode.js - A Quick Tour II
Node.js - A Quick Tour II
 
Node.js - A Quick Tour
Node.js - A Quick TourNode.js - A Quick Tour
Node.js - A Quick Tour
 
ActiveDOM
ActiveDOMActiveDOM
ActiveDOM
 

Recently uploaded

FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756
dollysharma2066
 
Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...
Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...
Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...
Sheetaleventcompany
 
Call Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service Bangalore
Call Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service BangaloreCall Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service Bangalore
Call Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service Bangalore
amitlee9823
 
0183760ssssssssssssssssssssssssssss00101011 (27).pdf
0183760ssssssssssssssssssssssssssss00101011 (27).pdf0183760ssssssssssssssssssssssssssss00101011 (27).pdf
0183760ssssssssssssssssssssssssssss00101011 (27).pdf
Renandantas16
 

Recently uploaded (20)

FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Majnu Ka Tilla, Delhi Contact Us 8377877756
 
How to Get Started in Social Media for Art League City
How to Get Started in Social Media for Art League CityHow to Get Started in Social Media for Art League City
How to Get Started in Social Media for Art League City
 
RSA Conference Exhibitor List 2024 - Exhibitors Data
RSA Conference Exhibitor List 2024 - Exhibitors DataRSA Conference Exhibitor List 2024 - Exhibitors Data
RSA Conference Exhibitor List 2024 - Exhibitors Data
 
Ensure the security of your HCL environment by applying the Zero Trust princi...
Ensure the security of your HCL environment by applying the Zero Trust princi...Ensure the security of your HCL environment by applying the Zero Trust princi...
Ensure the security of your HCL environment by applying the Zero Trust princi...
 
Monthly Social Media Update April 2024 pptx.pptx
Monthly Social Media Update April 2024 pptx.pptxMonthly Social Media Update April 2024 pptx.pptx
Monthly Social Media Update April 2024 pptx.pptx
 
Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...
Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...
Chandigarh Escorts Service 📞8868886958📞 Just📲 Call Nihal Chandigarh Call Girl...
 
Dr. Admir Softic_ presentation_Green Club_ENG.pdf
Dr. Admir Softic_ presentation_Green Club_ENG.pdfDr. Admir Softic_ presentation_Green Club_ENG.pdf
Dr. Admir Softic_ presentation_Green Club_ENG.pdf
 
👉Chandigarh Call Girls 👉9878799926👉Just Call👉Chandigarh Call Girl In Chandiga...
👉Chandigarh Call Girls 👉9878799926👉Just Call👉Chandigarh Call Girl In Chandiga...👉Chandigarh Call Girls 👉9878799926👉Just Call👉Chandigarh Call Girl In Chandiga...
👉Chandigarh Call Girls 👉9878799926👉Just Call👉Chandigarh Call Girl In Chandiga...
 
Call Girls Ludhiana Just Call 98765-12871 Top Class Call Girl Service Available
Call Girls Ludhiana Just Call 98765-12871 Top Class Call Girl Service AvailableCall Girls Ludhiana Just Call 98765-12871 Top Class Call Girl Service Available
Call Girls Ludhiana Just Call 98765-12871 Top Class Call Girl Service Available
 
VVVIP Call Girls In Greater Kailash ➡️ Delhi ➡️ 9999965857 🚀 No Advance 24HRS...
VVVIP Call Girls In Greater Kailash ➡️ Delhi ➡️ 9999965857 🚀 No Advance 24HRS...VVVIP Call Girls In Greater Kailash ➡️ Delhi ➡️ 9999965857 🚀 No Advance 24HRS...
VVVIP Call Girls In Greater Kailash ➡️ Delhi ➡️ 9999965857 🚀 No Advance 24HRS...
 
Falcon's Invoice Discounting: Your Path to Prosperity
Falcon's Invoice Discounting: Your Path to ProsperityFalcon's Invoice Discounting: Your Path to Prosperity
Falcon's Invoice Discounting: Your Path to Prosperity
 
Mondelez State of Snacking and Future Trends 2023
Mondelez State of Snacking and Future Trends 2023Mondelez State of Snacking and Future Trends 2023
Mondelez State of Snacking and Future Trends 2023
 
Famous Olympic Siblings from the 21st Century
Famous Olympic Siblings from the 21st CenturyFamous Olympic Siblings from the 21st Century
Famous Olympic Siblings from the 21st Century
 
Call Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service Bangalore
Call Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service BangaloreCall Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service Bangalore
Call Girls Hebbal Just Call 👗 7737669865 👗 Top Class Call Girl Service Bangalore
 
Pharma Works Profile of Karan Communications
Pharma Works Profile of Karan CommunicationsPharma Works Profile of Karan Communications
Pharma Works Profile of Karan Communications
 
Value Proposition canvas- Customer needs and pains
Value Proposition canvas- Customer needs and painsValue Proposition canvas- Customer needs and pains
Value Proposition canvas- Customer needs and pains
 
Phases of Negotiation .pptx
 Phases of Negotiation .pptx Phases of Negotiation .pptx
Phases of Negotiation .pptx
 
0183760ssssssssssssssssssssssssssss00101011 (27).pdf
0183760ssssssssssssssssssssssssssss00101011 (27).pdf0183760ssssssssssssssssssssssssssss00101011 (27).pdf
0183760ssssssssssssssssssssssssssss00101011 (27).pdf
 
Uneak White's Personal Brand Exploration Presentation
Uneak White's Personal Brand Exploration PresentationUneak White's Personal Brand Exploration Presentation
Uneak White's Personal Brand Exploration Presentation
 
Call Girls Service In Old Town Dubai ((0551707352)) Old Town Dubai Call Girl ...
Call Girls Service In Old Town Dubai ((0551707352)) Old Town Dubai Call Girl ...Call Girls Service In Old Town Dubai ((0551707352)) Old Town Dubai Call Girl ...
Call Girls Service In Old Town Dubai ((0551707352)) Old Town Dubai Call Girl ...
 

With jQuery & CakePHP to World Domination