| OLD | NEW | 
|---|
| 1 <div id="pageData-name" class="pageData">Overview</div> | 1 <div id="pageData-name" class="pageData">Overview</div> | 
| 2 <div id="pageData-showTOC" class="pageData">true</div> | 2 <div id="pageData-showTOC" class="pageData">true</div> | 
| 3 | 3 | 
| 4 <p> | 4 <p> | 
| 5 Once you've finished this page | 5 Once you've finished this page | 
| 6 and the | 6 and the | 
| 7 <a href="getstarted.html">Getting Started</a> tutorial, | 7 <a href="getstarted.html">Getting Started</a> tutorial, | 
| 8 you'll be all set to start writing extensions. | 8 you'll be all set to start writing extensions and packaged apps. | 
| 9 </p> | 9 </p> | 
| 10 | 10 | 
|  | 11 <p class="caution"> | 
|  | 12 <strong>Note:</strong> | 
|  | 13 <em>Packaged apps</em> are implemented as extensions, | 
|  | 14 so unless otherwise stated, | 
|  | 15 everything in this page applies to packaged apps. | 
|  | 16 </p> | 
| 11 | 17 | 
| 12 <h2 id="what">The basics</h2> | 18 <h2 id="what">The basics</h2> | 
| 13 | 19 | 
| 14 <p> | 20 <p> | 
| 15 An extension is a zipped bundle of files — | 21 An extension is a zipped bundle of files—HTML, | 
| 16 HTML, CSS, JavaScript, images, and anything else you need — | 22 CSS, JavaScript, images, and anything else you need—that | 
| 17 that adds functionality to the Google Chrome browser. | 23 adds functionality to the Google Chrome browser. | 
| 18 Extensions are essentially web pages, | 24 Extensions are essentially web pages, | 
| 19 and they can use all the | 25 and they can use all the | 
| 20 <a href="api_other.html">APIs that the browser provides to web pages</a>, | 26 <a href="api_other.html">APIs that the browser provides to web pages</a>, | 
| 21 from XMLHttpRequest to JSON to HTML5. | 27 from XMLHttpRequest to JSON to HTML5. | 
| 22 </p> | 28 </p> | 
| 23 | 29 | 
| 24 <p> | 30 <p> | 
| 25 Many extensions add UI to Google Chrome, | 31 Extensions can interact with web pages or servers using | 
| 26 in the form of | 32 <a href="content_scripts.html">content scripts</a> or | 
| 27 <a href="browserAction.html">browser actions</a> | 33 <a href="xhr.html">cross-origin XMLHttpRequests</a>. | 
| 28 or <a href="pageAction.html">page actions</a>. |  | 
| 29 Extensions can also interact programmatically | 34 Extensions can also interact programmatically | 
| 30 with browser features such as | 35 with browser features such as | 
| 31 <a href="bookmarks.html">bookmarks</a> | 36 <a href="bookmarks.html">bookmarks</a> | 
| 32 and <a href="tabs.html">tabs</a>. | 37 and <a href="tabs.html">tabs</a>. | 
| 33 To interact with web pages or servers, |  | 
| 34 extensions can use |  | 
| 35 <a href="content_scripts.html">content scripts</a> or |  | 
| 36 <a href="xhr.html">cross-origin XMLHttpRequests</a>. |  | 
| 37 </p> | 38 </p> | 
| 38 | 39 | 
|  | 40 <h3 id="extension-ui">Extension UIs</h3> | 
|  | 41 | 
| 39 <p> | 42 <p> | 
| 40 <b>Note:</b> | 43 Many extensions—but not packaged apps—add | 
|  | 44 UI to Google Chrome in the form of | 
|  | 45 <a href="browserAction.html">browser actions</a> | 
|  | 46 or <a href="pageAction.html">page actions</a>. | 
| 41 Each extension can have at most one browser action or page action. | 47 Each extension can have at most one browser action or page action. | 
| 42 Choose a <b>browser action</b> when the extension is relevant to most pages. | 48 Choose a <b>browser action</b> when the extension is relevant to most pages. | 
| 43 Choose a <b>page action</b> when the extension's icon | 49 Choose a <b>page action</b> when the extension's icon | 
| 44 should appear or disappear, | 50 should appear or disappear, | 
| 45 depending on the page. | 51 depending on the page. | 
| 46 </p> | 52 </p> | 
| 47 | 53 | 
|  | 54 <table class="columns"> | 
|  | 55 <tr> | 
|  | 56   <td> | 
|  | 57     <img src="images/index/gmail.png" | 
|  | 58       width="150" height="79" | 
|  | 59       alt="screenshot" /> | 
|  | 60   </td> | 
|  | 61   <td> | 
|  | 62     <img src="images/index/news.png" | 
|  | 63       width="150" height="79" | 
|  | 64       alt="screenshot" /> | 
|  | 65   </td> | 
|  | 66   <td> | 
|  | 67     <img src="images/index/rss.png" | 
|  | 68       width="150" height="79" | 
|  | 69       alt="screenshot" /> | 
|  | 70   </td> | 
|  | 71 </tr> | 
|  | 72 | 
|  | 73 <tr> | 
|  | 74   <td> | 
|  | 75     This <a href="samples.html#gmail">mail extension</a> | 
|  | 76     uses a <em>browser action</em> | 
|  | 77     (icon in the toolbar). | 
|  | 78   </td> | 
|  | 79   <td> | 
|  | 80     This <a href="samples.html#news">news reader extension</a> | 
|  | 81     features a browser action that, | 
|  | 82     when clicked, | 
|  | 83     shows a <em>popup</em>. | 
|  | 84   </td> | 
|  | 85   <td> | 
|  | 86     This <a href="samples.html#mappy">map extension</a> | 
|  | 87     uses a <em>page action</em> | 
|  | 88     (icon in the address bar) | 
|  | 89     and <em>content script</em> | 
|  | 90     (code injected into a web page). | 
|  | 91   </td> | 
|  | 92 </tr> | 
|  | 93 </table> | 
|  | 94 | 
| 48 <p> | 95 <p> | 
|  | 96 Extensions (and packaged apps) can also present a UI in other ways, | 
|  | 97 such as adding to the Chrome context menu, | 
|  | 98 providing an options page, | 
|  | 99 or using a content script that changes how pages look. | 
| 49 See the <a href="devguide.html">Developer's Guide</a> | 100 See the <a href="devguide.html">Developer's Guide</a> | 
| 50 for a complete list of extension features, | 101 for a complete list of extension features, | 
| 51 with implementation details | 102 with links to implementation details | 
| 52 for each one. | 103 for each one. | 
| 53 </p> | 104 </p> | 
| 54 | 105 | 
|  | 106 | 
|  | 107 <h3 id="packagedapp-ui">Packaged app UIs</h3> | 
|  | 108 | 
|  | 109 <p> | 
|  | 110 A packaged app usually presents its main functionality using | 
|  | 111 an HTML page that's bundled into the app. | 
|  | 112 For example, the following packaged app | 
|  | 113 displays a Flash file within an HTML page. | 
|  | 114 </p> | 
|  | 115 | 
|  | 116 <img src="images/index/flashapp.png" | 
|  | 117   width="372" height="300" | 
|  | 118   alt="screenshot" /> | 
|  | 119 | 
|  | 120 <p> | 
|  | 121 For more information, | 
|  | 122 see <a href="apps.html">Packaged Apps</a>. | 
|  | 123 </p> | 
|  | 124 | 
| 55 <h2 id="files">Files</h2> | 125 <h2 id="files">Files</h2> | 
| 56 <p> | 126 <p> | 
| 57 Each extension has the following files: | 127 Each extension has the following files: | 
| 58 <!-- PENDING: This could use a picture --> | 128 <!-- PENDING: This could use a picture --> | 
| 59 </p> | 129 </p> | 
| 60 | 130 | 
| 61 <ul> | 131 <ul> | 
| 62   <li>A <b>manifest file</b></li> | 132   <li>A <b>manifest file</b></li> | 
| 63   <li>One or more <b>HTML files</b> (unless the extension is a theme)</li> | 133   <li>One or more <b>HTML files</b> (unless the extension is a theme)</li> | 
| 64   <li><em>Optional:</em> One or more <b>JavaScript files</b></li> | 134   <li><em>Optional:</em> One or more <b>JavaScript files</b></li> | 
| 65   <li><em>Optional:</em> Any other files your extension needs — | 135   <li><em>Optional:</em> Any other files your extension needs—for | 
| 66   for example, image files</li> | 136   example, image files</li> | 
| 67 </ul> | 137 </ul> | 
| 68 | 138 | 
| 69 <p> | 139 <p> | 
| 70 While you're working on your extension, | 140 While you're working on your extension, | 
| 71 you put all these files into a single folder. | 141 you put all these files into a single folder. | 
| 72 When you distribute your extension, | 142 When you distribute your extension, | 
| 73 the contents of the folder are packaged into a special ZIP file | 143 the contents of the folder are packaged into a special ZIP file | 
| 74 that has a <code>.crx</code> suffix. | 144 that has a <code>.crx</code> suffix. | 
| 75 If you put your extension in the gallery, | 145 If you upload your extension using the | 
| 76 the gallery creates the <code>.crx</code> file for you. | 146 <a href="https://chrome.google.com/webstore/developer/dashboard">Chrome Develope
     r Dashboard</a>, | 
|  | 147 the <code>.crx</code> file is created for you. | 
| 77 For details on distributing extensions, | 148 For details on distributing extensions, | 
| 78 see <a href="hosting.html">Hosting</a>. | 149 see <a href="hosting.html">Hosting</a>. | 
| 79 </p> | 150 </p> | 
| 80 | 151 | 
| 81 | 152 | 
| 82 <h3 id="relative-urls">Referring to files</h3> | 153 <h3 id="relative-urls">Referring to files</h3> | 
| 83 | 154 | 
| 84 <p> | 155 <p> | 
| 85 You can put any file you like into an extension, | 156 You can put any file you like into an extension, | 
| 86 but how do you use it? | 157 but how do you use it? | 
| (...skipping 215 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 302 <h2 id="incognito"> Saving data and incognito mode </h2> | 373 <h2 id="incognito"> Saving data and incognito mode </h2> | 
| 303 | 374 | 
| 304 <p> | 375 <p> | 
| 305 Extensions can save data using | 376 Extensions can save data using | 
| 306 the HTML5 <a href="http://dev.w3.org/html5/webstorage/">web storage API</a> | 377 the HTML5 <a href="http://dev.w3.org/html5/webstorage/">web storage API</a> | 
| 307 (such as <code>localStorage</code>) | 378 (such as <code>localStorage</code>) | 
| 308 or by making server requests that result in saving data. | 379 or by making server requests that result in saving data. | 
| 309 Whenever you want to save something, | 380 Whenever you want to save something, | 
| 310 first consider whether it's | 381 first consider whether it's | 
| 311 from a window that's in incognito mode. | 382 from a window that's in incognito mode. | 
| 312 By default, extensions don't run in incognito windows. | 383 By default, extensions don't run in incognito windows, | 
| 313 However, users can selectively enable your extension for incognito mode, | 384 and packaged apps <em>do</em>. | 
| 314 so you need to consider what a user expects | 385 You need to consider what a user expects | 
| 315 from your extension in that case. | 386 from your extension or packaged app | 
|  | 387 when the browser is incognito. | 
| 316 </p> | 388 </p> | 
| 317 | 389 | 
| 318 <p> | 390 <p> | 
| 319 <em>Incognito mode</em> promises that the window will leave no tracks. | 391 <em>Incognito mode</em> promises that the window will leave no tracks. | 
| 320 When dealing with data from incognito windows, | 392 When dealing with data from incognito windows, | 
| 321 do your best to honor this promise. | 393 do your best to honor this promise. | 
| 322 For example, if your extension normally | 394 For example, if your extension normally | 
| 323 saves browsing history to the cloud, | 395 saves browsing history to the cloud, | 
| 324 don't save history from incognito windows. | 396 don't save history from incognito windows. | 
| 325 On the other hand, you can store | 397 On the other hand, you can store | 
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 365 <ul> | 437 <ul> | 
| 366   <li> <a href="getstarted.html">Tutorial: Getting Started</a> </li> | 438   <li> <a href="getstarted.html">Tutorial: Getting Started</a> </li> | 
| 367   <li> <a href="tut_debugging.html">Tutorial: Debugging</a> </li> | 439   <li> <a href="tut_debugging.html">Tutorial: Debugging</a> </li> | 
| 368   <li> <a href="devguide.html">Developer's Guide</a> </li> | 440   <li> <a href="devguide.html">Developer's Guide</a> </li> | 
| 369   <li> <a href="http://dev.chromium.org/developers/design-documents/extensions/s
     amples">Samples</a> </li> | 441   <li> <a href="http://dev.chromium.org/developers/design-documents/extensions/s
     amples">Samples</a> </li> | 
| 370   <li> <a href="http://www.youtube.com/view_play_list?p=CA101D6A85FE9D4B">Videos
     </a>, | 442   <li> <a href="http://www.youtube.com/view_play_list?p=CA101D6A85FE9D4B">Videos
     </a>, | 
| 371     such as | 443     such as | 
| 372     <a href="http://www.youtube.com/watch?v=B4M_a7xejYI&feature=PlayList&p=CA101
     D6A85FE9D4B&index=6">Extension Message Passing</a> | 444     <a href="http://www.youtube.com/watch?v=B4M_a7xejYI&feature=PlayList&p=CA101
     D6A85FE9D4B&index=6">Extension Message Passing</a> | 
| 373     </li> | 445     </li> | 
| 374 </ul> | 446 </ul> | 
| OLD | NEW | 
|---|