SlideShare une entreprise Scribd logo
1  sur  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

Contenu connexe

Tendances

Google chrome extension
Google chrome extensionGoogle chrome extension
Google chrome extensionJohnny Kingdom
 
HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09mihaiionescu
 
Introduction of chrome extension development
Introduction of chrome extension developmentIntroduction of chrome extension development
Introduction of chrome extension developmentBalduran Chang
 
Introduction to chrome extension development
Introduction to chrome extension developmentIntroduction to chrome extension development
Introduction to chrome extension developmentKAI CHU CHUNG
 
Making Chrome Extension with AngularJS
Making Chrome Extension with AngularJSMaking Chrome Extension with AngularJS
Making Chrome Extension with AngularJSBen Lau
 
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 Extensionchaykaborya
 
Effective TDD - Less is more
Effective TDD - Less is moreEffective TDD - Less is more
Effective TDD - Less is moreBen Lau
 
Creating chrome-extension
Creating chrome-extensionCreating chrome-extension
Creating chrome-extensionAkshay Khale
 
Dive Into Chrome-100119
Dive Into Chrome-100119Dive Into Chrome-100119
Dive Into Chrome-100119yiming he
 
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 themescodebangla
 
WordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10nWordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10ncodebangla
 
Basic Introduction to Web Development
Basic Introduction to Web DevelopmentBasic Introduction to Web Development
Basic Introduction to Web DevelopmentBurhan Khalid
 
Introduction to web development
Introduction to web developmentIntroduction to web development
Introduction to web developmentAlberto Apellidos
 
Leksion 1 hyrje ne xhtml
Leksion 1   hyrje ne xhtmlLeksion 1   hyrje ne xhtml
Leksion 1 hyrje ne xhtmlmariokenga
 
Chapter 1
Chapter 1Chapter 1
Chapter 1Uma Sam
 
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 DevelopmentRandy Connolly
 
Basic Wordpress PPT
Basic Wordpress PPT Basic Wordpress PPT
Basic Wordpress PPT mayur akabari
 

Tendances (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
 

En vedette

Uas pembelajaran matematika
Uas pembelajaran matematikaUas pembelajaran matematika
Uas pembelajaran matematikaChamida Ni'mah
 
Self hosted server applications - Adam Horvath
Self hosted server applications - Adam HorvathSelf hosted server applications - Adam Horvath
Self hosted server applications - Adam Horvathadamhorvath
 
1475243 634781082078971250
1475243 6347810820789712501475243 634781082078971250
1475243 634781082078971250Akshaya_J
 
Hfov presentation (abdul fattah)
Hfov  presentation (abdul fattah) Hfov  presentation (abdul fattah)
Hfov presentation (abdul fattah) Abdul Fatah Abro
 
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...adamhorvath
 
Volutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatahVolutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatahAbdul Fatah Abro
 
Neonatal assisted ventilation
Neonatal assisted ventilation   Neonatal assisted ventilation
Neonatal assisted ventilation Abdul Fatah Abro
 

En vedette (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
 

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

Creating Your Own Static Website Generator
Creating Your Own Static Website GeneratorCreating Your Own Static Website Generator
Creating Your Own Static Website GeneratorSean O'Mahoney
 
HTML5 Technical Executive Summary
HTML5 Technical Executive SummaryHTML5 Technical Executive Summary
HTML5 Technical Executive SummaryGilad Khen
 
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 todayRandy Williams
 
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 2017Imran Qasim
 
HTML5 and the Open Web Platform
HTML5 and the Open Web PlatformHTML5 and the Open Web Platform
HTML5 and the Open Web PlatformBeat Signer
 
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 2017LumoLink
 
Western web work Jan 25, 2013
Western web work Jan 25, 2013Western web work Jan 25, 2013
Western web work Jan 25, 2013Marie Toler Raney
 
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 Peyman Fakharian
 
Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013Nabil Babaci
 
Developing for Windows Phone 7
Developing for Windows Phone 7Developing for Windows Phone 7
Developing for Windows Phone 7Gergely Orosz
 
Mix Tech Ed Update No Video
Mix Tech Ed Update No VideoMix Tech Ed Update No Video
Mix Tech Ed Update No VideoAllyWick
 
How websites and search engines work
How websites and search engines workHow websites and search engines work
How websites and search engines workBrian Duffy
 
A Microsoft primer for PHP devs
A Microsoft primer for PHP devsA Microsoft primer for PHP devs
A Microsoft primer for PHP devsguest0a62e8
 
Getting Started with SharePoint Branding
Getting Started with SharePoint BrandingGetting Started with SharePoint Branding
Getting Started with SharePoint BrandingThomas 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 brandingThomas Daly
 
Angular jS Introduction by Google
Angular jS Introduction by GoogleAngular jS Introduction by Google
Angular jS Introduction by GoogleASG
 

Similaire à 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
 

Dernier

How to Manage Global Discount in Odoo 17 POS
How to Manage Global Discount in Odoo 17 POSHow to Manage Global Discount in Odoo 17 POS
How to Manage Global Discount in Odoo 17 POSCeline George
 
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...Nguyen Thanh Tu Collection
 
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.pdfNirmal Dwivedi
 
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...Pooja Bhuva
 
Unit-V; Pricing (Pharma Marketing Management).pptx
Unit-V; Pricing (Pharma Marketing Management).pptxUnit-V; Pricing (Pharma Marketing Management).pptx
Unit-V; Pricing (Pharma Marketing Management).pptxVishalSingh1417
 
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...Poonam Aher Patil
 
SOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning PresentationSOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning Presentationcamerronhm
 
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 17Celine George
 
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptxSKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptxAmanpreet Kaur
 
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...Nguyen Thanh Tu Collection
 
Making communications land - Are they received and understood as intended? we...
Making communications land - Are they received and understood as intended? we...Making communications land - Are they received and understood as intended? we...
Making communications land - Are they received and understood as intended? we...Association for Project Management
 
The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxheathfieldcps1
 
Basic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptxBasic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptxDenish Jangid
 
Key note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdfKey note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdfAdmir Softic
 
Wellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptxWellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptxJisc
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibitjbellavia9
 
How to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptxHow to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptxCeline George
 
Food safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdfFood safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdfSherif Taha
 
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...Pooja Bhuva
 
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.pdfPoh-Sun Goh
 

Dernier (20)

How to Manage Global Discount in Odoo 17 POS
How to Manage Global Discount in Odoo 17 POSHow to Manage Global Discount in Odoo 17 POS
How to Manage Global Discount in Odoo 17 POS
 
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
 
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
 
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...
 
Unit-V; Pricing (Pharma Marketing Management).pptx
Unit-V; Pricing (Pharma Marketing Management).pptxUnit-V; Pricing (Pharma Marketing Management).pptx
Unit-V; Pricing (Pharma Marketing Management).pptx
 
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...
 
SOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning PresentationSOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning Presentation
 
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
 
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptxSKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
SKILL OF INTRODUCING THE LESSON MICRO SKILLS.pptx
 
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
 
Making communications land - Are they received and understood as intended? we...
Making communications land - Are they received and understood as intended? we...Making communications land - Are they received and understood as intended? we...
Making communications land - Are they received and understood as intended? we...
 
The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptx
 
Basic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptxBasic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptx
 
Key note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdfKey note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdf
 
Wellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptxWellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptx
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibit
 
How to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptxHow to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptx
 
Food safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdfFood safety_Challenges food safety laboratories_.pdf
Food safety_Challenges food safety laboratories_.pdf
 
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
Beyond_Borders_Understanding_Anime_and_Manga_Fandom_A_Comprehensive_Audience_...
 
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
 

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