SlideShare ist ein Scribd-Unternehmen logo
1 von 14
Chrome/Chromium extension development Presenter: 	Adam Horvath 	(adam@teamleadnet.com) 1 Adam Horvath September 27, 2011 - Sydney
What is a Chrome extension? Chrome policy: only add features that everyone will use Extra functionality added to pages or generally, to the browser Usually written using standard ‘web technologies’ Javascript HTML CSS JSON/XML data Special ZIP package with header information 2 Adam Horvath September 27, 2011 - Sydney
Why is it interesting? Business cases Add extra/new functionality to legacy systems Translate  (localise) an existing web UI Provide custom UI for third party services Learn proper/sustainable (Java)script programming Increasing your ‘brand awareness’ However: unlikely to sell from the store! 3 Adam Horvath September 27, 2011 - Sydney
Types of extensions Browser action (for every webpage) Page action (based/filtered on the URL) Override pages (Bookmark manager, History, New tab) Omnibox helpers (custom search function) NPAPI native code (Netscape Plugin Application Programming Interface) (Themes) 4 Adam Horvath September 27, 2011 - Sydney
Supporting pages/objects Background page (always running) Options page (opened when necessary) Popup page (for browser actions) Content (scripts, css, ...) Desktop notification 5 Adam Horvath September 27, 2011 - Sydney
6 Adam Horvath September 27, 2011 - Sydney
Messaging / storage Isolated world – One page, multiple extensions, no collision Almost all of the APIs are async Async communication between processes Send messages between extension/background pages Cross domain XMLHttpRequest / External services Storage (localStorage, 5Mb) 7 Adam Horvath September 27, 2011 - Sydney
Browser interaction Need to ask for permissions before installing Chrome.* namespace can access Bookmarks Cookies Events History Management Tabs Windows APIs are never removed after making their way into Stable branch 8 Adam Horvath September 27, 2011 - Sydney
Hosting / publishing Manifest JSON description or the extension Chrome web store (easy autoupdate) Free to host Connects with Google Analytics Can upload sample screenshots/YouTube video Custom location (Autoupdate possible) 9 Adam Horvath September 27, 2011 - Sydney
How to develop Need a good toolset Netbeans, Closure compiler, SED, batch job Crafting by small modules, iteratively Create sample page with sample Javascript Test, fix Merge into extension Testing (unpacked, compiled + packed) Debugging Do not rely on debugging, although Chrome is a good debugger Embedding images in CSS (base64) 10 Adam Horvath September 27, 2011 - Sydney
Demo 11 Adam Horvath September 27, 2011 - Sydney
Final thoughts Platform problems Users might randomly report ‘Does not work for me’ Psychology of voting Hard to change the vote average after just a few votes Votes are dependent on the type of audience Localisation Not covered here, but extensions can support many languages 12 Adam Horvath September 27, 2011 - Sydney
URLs This presentationhttp://slidesha.re/chromeextension efTwo (F2) Advanced Find on Pagehttp://bit.ly/eftwochrome Chrome Extensions Getting Started http://code.google.com/chrome/extensions Closure compilerhttp://code.google.com/closure/compiler/ Image/CSS converterhttp://webcodertools.com/imagetobase64converter encoded = urllib.parse.quote( base64.b64encode(open(filename, "rb").read()) ) Netbeanshttp://netbeans.org/downloads/ GNU Win32 (sed)http://sourceforge.net/projects/gnuwin32 13 Adam Horvath September 27, 2011 - Sydney
Questions 14 Adam Horvath Adam Horvath  (adam@teamleadnet.com) September 27, 2011 - Sydney

Weitere ähnliche Inhalte

Was ist angesagt?

Google chrome extension
Google chrome extensionGoogle chrome extension
Google chrome extension
Johnny Kingdom
 
Effective TDD - Less is more
Effective TDD - Less is moreEffective TDD - Less is more
Effective TDD - Less is more
Ben Lau
 
Using disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themesUsing disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themes
codebangla
 
Leksion 1 hyrje ne xhtml
Leksion 1   hyrje ne xhtmlLeksion 1   hyrje ne xhtml
Leksion 1 hyrje ne xhtml
mariokenga
 
Chapter 1
Chapter 1Chapter 1
Chapter 1
Uma Sam
 

Was ist angesagt? (20)

Google chrome extension
Google chrome extensionGoogle chrome extension
Google chrome extension
 
HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09
 
Introduction of chrome extension development
Introduction of chrome extension developmentIntroduction of chrome extension development
Introduction of chrome extension development
 
Introduction to chrome extension development
Introduction to chrome extension developmentIntroduction to chrome extension development
Introduction to chrome extension development
 
Making Chrome Extension with AngularJS
Making Chrome Extension with AngularJSMaking Chrome Extension with AngularJS
Making Chrome Extension with AngularJS
 
Orange is the new blue: How to port Chrome Extension to Firefox Extension
Orange is the new blue: How to port Chrome Extension to Firefox ExtensionOrange is the new blue: How to port Chrome Extension to Firefox Extension
Orange is the new blue: How to port Chrome Extension to Firefox Extension
 
Effective TDD - Less is more
Effective TDD - Less is moreEffective TDD - Less is more
Effective TDD - Less is more
 
Develop Chrome Extension
Develop Chrome ExtensionDevelop Chrome Extension
Develop Chrome Extension
 
Creating chrome-extension
Creating chrome-extensionCreating chrome-extension
Creating chrome-extension
 
Chrome Extension
Chrome ExtensionChrome Extension
Chrome Extension
 
Dive Into Chrome-100119
Dive Into Chrome-100119Dive Into Chrome-100119
Dive Into Chrome-100119
 
Browser extension
Browser extensionBrowser extension
Browser extension
 
Using disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themesUsing disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themes
 
WordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10nWordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10n
 
Basic Introduction to Web Development
Basic Introduction to Web DevelopmentBasic Introduction to Web Development
Basic Introduction to Web Development
 
Introduction to web development
Introduction to web developmentIntroduction to web development
Introduction to web development
 
Leksion 1 hyrje ne xhtml
Leksion 1   hyrje ne xhtmlLeksion 1   hyrje ne xhtml
Leksion 1 hyrje ne xhtml
 
Chapter 1
Chapter 1Chapter 1
Chapter 1
 
WEB I - 01 - Introduction to Web Development
WEB I - 01 - Introduction to Web DevelopmentWEB I - 01 - Introduction to Web Development
WEB I - 01 - Introduction to Web Development
 
Basic Wordpress PPT
Basic Wordpress PPT Basic Wordpress PPT
Basic Wordpress PPT
 

Andere mochten auch

Uas pembelajaran matematika
Uas pembelajaran matematikaUas pembelajaran matematika
Uas pembelajaran matematika
Chamida Ni'mah
 
1475243 634781082078971250
1475243 6347810820789712501475243 634781082078971250
1475243 634781082078971250
Akshaya_J
 
Volutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatahVolutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatah
Abdul Fatah Abro
 
Neonatal assisted ventilation
Neonatal assisted ventilation   Neonatal assisted ventilation
Neonatal assisted ventilation
Abdul Fatah Abro
 

Andere mochten auch (14)

Powerful presentation
Powerful presentationPowerful presentation
Powerful presentation
 
Uas pembelajaran matematika
Uas pembelajaran matematikaUas pembelajaran matematika
Uas pembelajaran matematika
 
Self hosted server applications - Adam Horvath
Self hosted server applications - Adam HorvathSelf hosted server applications - Adam Horvath
Self hosted server applications - Adam Horvath
 
1475243 634781082078971250
1475243 6347810820789712501475243 634781082078971250
1475243 634781082078971250
 
Picc line by abdul fatah
Picc line by abdul fatahPicc line by abdul fatah
Picc line by abdul fatah
 
Hfov presentation (abdul fattah)
Hfov  presentation (abdul fattah) Hfov  presentation (abdul fattah)
Hfov presentation (abdul fattah)
 
Respiratory acidosis
Respiratory acidosisRespiratory acidosis
Respiratory acidosis
 
MapReduce frameworks and methods - Adam Horvath, Google Technology User Grou...
MapReduce frameworks and methods  - Adam Horvath, Google Technology User Grou...MapReduce frameworks and methods  - Adam Horvath, Google Technology User Grou...
MapReduce frameworks and methods - Adam Horvath, Google Technology User Grou...
 
Volutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatahVolutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatah
 
Neonatal physiology
Neonatal  physiologyNeonatal  physiology
Neonatal physiology
 
Neonatal assisted ventilation
Neonatal assisted ventilation   Neonatal assisted ventilation
Neonatal assisted ventilation
 
American Industrial Revolution
American Industrial RevolutionAmerican Industrial Revolution
American Industrial Revolution
 
Mattel ppt
Mattel pptMattel ppt
Mattel ppt
 
PGE tube
PGE tube PGE tube
PGE tube
 

Ähnlich wie Chrome Extension Development - Adam Horvath, Google Technology User Group, Sydney

Developing for Windows Phone 7
Developing for Windows Phone 7Developing for Windows Phone 7
Developing for Windows Phone 7
Gergely Orosz
 
Mix Tech Ed Update No Video
Mix Tech Ed Update No VideoMix Tech Ed Update No Video
Mix Tech Ed Update No Video
AllyWick
 
Getting Started with SharePoint Branding
Getting Started with SharePoint BrandingGetting Started with SharePoint Branding
Getting Started with SharePoint Branding
Thomas Daly
 
SPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point brandingSPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point branding
Thomas Daly
 

Ähnlich wie Chrome Extension Development - Adam Horvath, Google Technology User Group, Sydney (20)

Creating Your Own Static Website Generator
Creating Your Own Static Website GeneratorCreating Your Own Static Website Generator
Creating Your Own Static Website Generator
 
Ui development frameworks html-bootstrap by awa
Ui development frameworks html-bootstrap by awaUi development frameworks html-bootstrap by awa
Ui development frameworks html-bootstrap by awa
 
HTML5 Technical Executive Summary
HTML5 Technical Executive SummaryHTML5 Technical Executive Summary
HTML5 Technical Executive Summary
 
Building the next generation of browser apps today
Building the next generation of browser apps todayBuilding the next generation of browser apps today
Building the next generation of browser apps today
 
Ie9 overview
Ie9 overviewIe9 overview
Ie9 overview
 
Become a Successful Web Developer in Web development Field in 2017
Become a Successful Web Developer in Web development Field in 2017Become a Successful Web Developer in Web development Field in 2017
Become a Successful Web Developer in Web development Field in 2017
 
HTML5 and the Open Web Platform
HTML5 and the Open Web PlatformHTML5 and the Open Web Platform
HTML5 and the Open Web Platform
 
Going Back to Static HTML Sites - SEMPRO 2017
Going Back to Static HTML Sites - SEMPRO 2017Going Back to Static HTML Sites - SEMPRO 2017
Going Back to Static HTML Sites - SEMPRO 2017
 
Western web work Jan 25, 2013
Western web work Jan 25, 2013Western web work Jan 25, 2013
Western web work Jan 25, 2013
 
Web UI Tests: Introduce UI tests using Selenium
Web UI Tests: Introduce UI tests using Selenium Web UI Tests: Introduce UI tests using Selenium
Web UI Tests: Introduce UI tests using Selenium
 
Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013
 
Developing for Windows Phone 7
Developing for Windows Phone 7Developing for Windows Phone 7
Developing for Windows Phone 7
 
Wordpress as a CMS
Wordpress as a CMSWordpress as a CMS
Wordpress as a CMS
 
Mix Tech Ed Update No Video
Mix Tech Ed Update No VideoMix Tech Ed Update No Video
Mix Tech Ed Update No Video
 
Lecture 6 Data Driven Design
Lecture 6  Data Driven DesignLecture 6  Data Driven Design
Lecture 6 Data Driven Design
 
How websites and search engines work
How websites and search engines workHow websites and search engines work
How websites and search engines work
 
A Microsoft primer for PHP devs
A Microsoft primer for PHP devsA Microsoft primer for PHP devs
A Microsoft primer for PHP devs
 
Getting Started with SharePoint Branding
Getting Started with SharePoint BrandingGetting Started with SharePoint Branding
Getting Started with SharePoint Branding
 
SPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point brandingSPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point branding
 
Angular jS Introduction by Google
Angular jS Introduction by GoogleAngular jS Introduction by Google
Angular jS Introduction by Google
 

Kürzlich hochgeladen

Kürzlich hochgeladen (20)

UGC NET Paper 1 Mathematical Reasoning & Aptitude.pdf
UGC NET Paper 1 Mathematical Reasoning & Aptitude.pdfUGC NET Paper 1 Mathematical Reasoning & Aptitude.pdf
UGC NET Paper 1 Mathematical Reasoning & Aptitude.pdf
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibit
 
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptxOn_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
 
Graduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - EnglishGraduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - English
 
Python Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docxPython Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docx
 
How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17
 
ICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptxICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptx
 
Kodo Millet PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
Kodo Millet  PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...Kodo Millet  PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
Kodo Millet PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
 
Single or Multiple melodic lines structure
Single or Multiple melodic lines structureSingle or Multiple melodic lines structure
Single or Multiple melodic lines structure
 
Micro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdfMicro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdf
 
How to Create and Manage Wizard in Odoo 17
How to Create and Manage Wizard in Odoo 17How to Create and Manage Wizard in Odoo 17
How to Create and Manage Wizard in Odoo 17
 
This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.
 
Google Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptxGoogle Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptx
 
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
Sensory_Experience_and_Emotional_Resonance_in_Gabriel_Okaras_The_Piano_and_Th...
 
General Principles of Intellectual Property: Concepts of Intellectual Proper...
General Principles of Intellectual Property: Concepts of Intellectual  Proper...General Principles of Intellectual Property: Concepts of Intellectual  Proper...
General Principles of Intellectual Property: Concepts of Intellectual Proper...
 
Exploring_the_Narrative_Style_of_Amitav_Ghoshs_Gun_Island.pptx
Exploring_the_Narrative_Style_of_Amitav_Ghoshs_Gun_Island.pptxExploring_the_Narrative_Style_of_Amitav_Ghoshs_Gun_Island.pptx
Exploring_the_Narrative_Style_of_Amitav_Ghoshs_Gun_Island.pptx
 
FSB Advising Checklist - Orientation 2024
FSB Advising Checklist - Orientation 2024FSB Advising Checklist - Orientation 2024
FSB Advising Checklist - Orientation 2024
 
Fostering Friendships - Enhancing Social Bonds in the Classroom
Fostering Friendships - Enhancing Social Bonds  in the ClassroomFostering Friendships - Enhancing Social Bonds  in the Classroom
Fostering Friendships - Enhancing Social Bonds in the Classroom
 
Interdisciplinary_Insights_Data_Collection_Methods.pptx
Interdisciplinary_Insights_Data_Collection_Methods.pptxInterdisciplinary_Insights_Data_Collection_Methods.pptx
Interdisciplinary_Insights_Data_Collection_Methods.pptx
 
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptxHMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
 

Chrome Extension Development - Adam Horvath, Google Technology User Group, Sydney

  • 1. Chrome/Chromium extension development Presenter: Adam Horvath (adam@teamleadnet.com) 1 Adam Horvath September 27, 2011 - Sydney
  • 2. What is a Chrome extension? Chrome policy: only add features that everyone will use Extra functionality added to pages or generally, to the browser Usually written using standard ‘web technologies’ Javascript HTML CSS JSON/XML data Special ZIP package with header information 2 Adam Horvath September 27, 2011 - Sydney
  • 3. Why is it interesting? Business cases Add extra/new functionality to legacy systems Translate (localise) an existing web UI Provide custom UI for third party services Learn proper/sustainable (Java)script programming Increasing your ‘brand awareness’ However: unlikely to sell from the store! 3 Adam Horvath September 27, 2011 - Sydney
  • 4. Types of extensions Browser action (for every webpage) Page action (based/filtered on the URL) Override pages (Bookmark manager, History, New tab) Omnibox helpers (custom search function) NPAPI native code (Netscape Plugin Application Programming Interface) (Themes) 4 Adam Horvath September 27, 2011 - Sydney
  • 5. Supporting pages/objects Background page (always running) Options page (opened when necessary) Popup page (for browser actions) Content (scripts, css, ...) Desktop notification 5 Adam Horvath September 27, 2011 - Sydney
  • 6. 6 Adam Horvath September 27, 2011 - Sydney
  • 7. Messaging / storage Isolated world – One page, multiple extensions, no collision Almost all of the APIs are async Async communication between processes Send messages between extension/background pages Cross domain XMLHttpRequest / External services Storage (localStorage, 5Mb) 7 Adam Horvath September 27, 2011 - Sydney
  • 8. Browser interaction Need to ask for permissions before installing Chrome.* namespace can access Bookmarks Cookies Events History Management Tabs Windows APIs are never removed after making their way into Stable branch 8 Adam Horvath September 27, 2011 - Sydney
  • 9. Hosting / publishing Manifest JSON description or the extension Chrome web store (easy autoupdate) Free to host Connects with Google Analytics Can upload sample screenshots/YouTube video Custom location (Autoupdate possible) 9 Adam Horvath September 27, 2011 - Sydney
  • 10. How to develop Need a good toolset Netbeans, Closure compiler, SED, batch job Crafting by small modules, iteratively Create sample page with sample Javascript Test, fix Merge into extension Testing (unpacked, compiled + packed) Debugging Do not rely on debugging, although Chrome is a good debugger Embedding images in CSS (base64) 10 Adam Horvath September 27, 2011 - Sydney
  • 11. Demo 11 Adam Horvath September 27, 2011 - Sydney
  • 12. Final thoughts Platform problems Users might randomly report ‘Does not work for me’ Psychology of voting Hard to change the vote average after just a few votes Votes are dependent on the type of audience Localisation Not covered here, but extensions can support many languages 12 Adam Horvath September 27, 2011 - Sydney
  • 13. URLs This presentationhttp://slidesha.re/chromeextension efTwo (F2) Advanced Find on Pagehttp://bit.ly/eftwochrome Chrome Extensions Getting Started http://code.google.com/chrome/extensions Closure compilerhttp://code.google.com/closure/compiler/ Image/CSS converterhttp://webcodertools.com/imagetobase64converter encoded = urllib.parse.quote( base64.b64encode(open(filename, "rb").read()) ) Netbeanshttp://netbeans.org/downloads/ GNU Win32 (sed)http://sourceforge.net/projects/gnuwin32 13 Adam Horvath September 27, 2011 - Sydney
  • 14. Questions 14 Adam Horvath Adam Horvath (adam@teamleadnet.com) September 27, 2011 - Sydney