1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
|
---
title: Interieur de l'Inspecteur DOM
slug: Inspecteur_DOM/Internals
translation_of: Tools/Add-ons/DOM_Inspector/Internals
---
<div>{{ToolsSidebar}}</div><div class="note">
<p>L'Inspecteur DOM est un module complémentaire pour les applications basées sur XUL comme Firefox ou Thunderbird. Si vous cherchez l'Inspecteur DOM intégré à Firefox, regardez plutôt la documentation pour <a href="/fr/docs/Tools/Page_Inspector">L'Inspecteur</a>.</p>
</div>
<p>Il ya trois parties principales dans l'Inspecteur DOM. La plus utilisée est l'interface utilisateur principale basée sur <code>inspector.xul</code>. il s'agit de l'Inspecteur à deux panneaux qui apparait au lancement de l'outil.</p>
<p><img alt="DOM Inspector primary UI inspecting browser.xul" class="default internal" src="/@api/deki/files/4686/=domi-edit-search-onclick.png"></p>
<p>En dehors de l'interface principale de l'Inspecteur DOM, il y a quelques autres inspecteurs haut-niveau qui diffèrent légèrement (l'inspecteur d'objets et le panneau latéral de l'Inspecteur DOM utilisé dans SeaMonkey). Nous allons d'abord nous concentrer sur <code>inspector.xul</code> et son point d'entrée, puis nous allons ensuite expliquer comment ces autres inspecteurs diffèrent.</p>
<h2 id="L'Inspecteur_DOM_d'un_point_de_vue_haut_niveau">L'Inspecteur DOM d'un point de vue haut niveau</h2>
<p>L'interface utilisateur principale de l'Inspecteur DOM est composée de barres d'outils et d'un "<strong>panelset</strong>." Le panelset contient deux panneaux. Un qui réagit aux changements occurrents dans le document inspecté. Et un qui réagit aux changements dans la sélection du premier panneau. Il s'agit respectivement du panneau document et du panneau objet.</p>
<p>Le but d'un panneau est de gérer les <strong>"viewers</strong>" disponibles. En haut de chaque panneau, se trouve une barre d'outils qui contient :un bouton menu permettant de choisir quel viewer afficher parmi la <strong>viewer list</strong>, une étiquette affichant le nom du viewer actuel, et un autre bouton permettant d'effectuer des actions spécifiques au viewer.</p>
<p>Les viewers sont chargés dynamiquement. Lorsqu'un panneau reçoit l'ordre de changer de viewer, l'ancien viewer est détruit et le nouveau est chargé à la place. Ainsi le panelset et les panneaux fonctionnent comme des frameset et frames. Cette comparaison s'avère très proche de la réalité, car chaque panneau contient en réalité un <code><a href="/fr/XUL/browser" title="en/XUL/browser">browser</a></code> anonyme, et, car chaque viewer existe dans un document séparé chargé dans le navigateur. Cette séparation permet aux viewers d'être indépendants, aec un XUL de viewer défini dans son propre document et chargé dans sa propre portée, cela sans crainte de collisions entre le XUL, le CSS ou le JS. Une autre conséquence est qu’en utilisant un <a href="/fr/Setting_up_an_extension_development_environment" title="en/Setting up an extension development environment">profil de développement</a> correctement configuré, alors la plupart des changements développés sont visibles uniquement en changeant de viewer puis en revenant sur le viewer précédant.</p>
<p>Sachant comment les viewers sont écrits, il est maintenant possible de jeter un oeil à l'organisation du code source de l'Inspecteur DOM.d</p>
<h2 id="Organisation_du_code_source">Organisation du code source</h2>
<p>Le contenu du dossier racine de l'Inspecteur DOM devrait ressembler à ceci :</p>
<ul>
<li>base/
<ul>
<li>js/
<ul>
<li>inspector-cmdline.js</li>
<li>Makefile.in</li>
</ul>
</li>
</ul>
</li>
<li>build/
<ul>
<li>install.js</li>
<li>Makefile.in</li>
</ul>
</li>
<li>resources/
<ul>
<li>content/
<ul>
<li><var>…</var></li>
</ul>
</li>
<li>locale/
<ul>
<li><var>…</var></li>
</ul>
</li>
<li>skin/
<ul>
<li><var>…</var></li>
</ul>
</li>
<li>Makefile.in</li>
</ul>
</li>
<li>install.rdf</li>
<li>jar.mn</li>
<li>Makefile.in</li>
<li>makefiles.sh</li>
</ul>
<p>Pratiquement toute la partie intéressante se trouve dans le dossier resources/content/. Son contenu devrait ressembler à ceci :</p>
<ul>
<li>extensions/
<ul>
<li>…</li>
</ul>
</li>
<li>jsutil/
<ul>
<li>…</li>
</ul>
</li>
<li>prefs/
<ul>
<li>…</li>
</ul>
</li>
<li>res/
<ul>
<li>…</li>
</ul>
</li>
<li>tests/
<ul>
<li>…</li>
</ul>
</li>
<li>viewers/
<ul>
<li>…</li>
</ul>
</li>
<li>browserOverlay.xul</li>
<li>commandOverlay.xul</li>
<li>editingOverlay.xul</li>
<li>Flasher.js</li>
<li>hooks.js</li>
<li>inspector.css</li>
<li>inspector.js</li>
<li>inspectorOverlay.xul</li>
<li>inspector.xml</li>
<li>inspector.xul</li>
<li>keysetOverlay.xul</li>
<li>object.js</li>
<li>object.xul</li>
<li>popupOverlay.xul</li>
<li>sidebar.js</li>
<li>sidebar.xul</li>
<li>statusbarOverlay.xul</li>
<li>tasksOverlay-cz.xul</li>
<li>tasksOverlay-ff.xul</li>
<li>tasksOverlay-mobile.xul</li>
<li>tasksOverlay-sb.xul</li>
<li>tasksOverlay-tb.xul</li>
<li>tasksOverlay.xul</li>
<li>toolboxOverlay.xul</li>
<li>utils.js</li>
<li>venkmanOverlay.xul</li>
<li>ViewerRegistry.js</li>
</ul>
<h3 id="Superpositions_(Overlays)">Superpositions (Overlays)</h3>
<p>Il y a de nombreux overlays. Certains overlays peuvent être décrits comme des overlays d'intégration hôte, et d'autres comme des overlays à structure partagée.</p>
<h4 id="Overlays_d'intégration_hôte">Overlays d'intégration hôte</h4>
<p>L'Inspecteur DOM est une extension à utilité générique, adaptée à une utilisation avec n'importe quel toolkit d'application hôte de Mozilla. Afin que l'Inspecteur DOM soit utile avec son application hôte, il doit obligatoirement y avoir un moyen de lancer l'Inspecteur DOM depuis l'intérieur de l'application. Soit l'application fournit ces moyens eux-mêmes (généralement en intégrant l'Inspecteur DOM dans l'application), soit l'Inspecteur DOM doit explicitement supporter l'application en ayant ses propres options de menus et/ou raccourcis clavier avec des overlays d'intégration hôte.</p>
<p>L'Inspecteur DOM supporte explicitement plusieurs applications Mozilla en fournissant des overlays d'intégration hôte. Ces overlays sont :</p>
<ul>
<li>browserOverlay.xul</li>
<li>tasksOverlay-cz.xul</li>
<li>tasksOverlay-ff.xul</li>
<li>tasksOverlay-mobile.xul</li>
<li>tasksOverlay-sb.xul</li>
<li>tasksOverlay-tb.xul</li>
<li>tasksOverlay.xul</li>
<li>venkmanOverlay.xul</li>
<li>prefs/prefsOverlay.xul</li>
</ul>
<p>Un examen plus approfondi du <a href="/fr/chrome.manifest" title="en/chrome.manifest">manifeste chrome</a> révèlera que l'Inspecteur DOM utilise également des overlays conditionnels dans sa fenêtre principale :</p>
<pre><code>overlay chrome://inspector/content/inspector.xul chrome://communicator/content/utilityOverlay.xul application={92650c4d-4b8e-4d2a-b7eb-24ecf4f6b63a}
overlay chrome://inspector/content/inspector.xul chrome://communicator/content/tasksOverlay.xul application={92650c4d-4b8e-4d2a-b7eb-24ecf4f6b63a}</code>
</pre>
<pre><code>overlay chrome://inspector/content/inspector.xul chrome://browser/content/baseMenuOverlay.xul application={ec8030f7-c20a-464f-9b0e-13a3a9e97384}</code>
</pre>
<p>Ces overlays fournis par l'hôte permettent à l'Inspecteur DOM d'adopter une apparence et des sensations similaires à l'application hôte. (Au-dessus, respectivement SeaMonkey et Firefox).</p>
<p>Il y a plusieurs overlays dans le dossier "resources/contents/" qui ne font pas partie de cette catégorie d'overlays d'intégration hôte. En effet, l'Inspecteur DOM utilise également des overlays partagés pour construire sa propre interface utilisateur.</p>
<h4 id="Overlays_à_structure_partagée">Overlays à structure partagée</h4>
<p>Jetter un oeil au contenu du fichier inspector.xul de l'interface utilisateur principale de l'Inspecteur DOM révélera qu'il ne contient quasiment aucun élément visible. Au moment présent, il a une <code><a href="/fr/XUL/toolbox" title="en/XUL/toolbox">boite à outils</a></code> contenant un <code><a href="/fr/XUL/menubar" title="en/XUL/menubar">menubar</a></code> vide et une <code><a href="/fr/XUL/toolbar" title="en/XUL/toolbar">barre d'outils</a></code> vide, ainsi qu'une <code><a href="/fr/XUL/vbox" title="en/XUL/vbox">vbox</a></code> vide :</p>
<pre><code> <toolbox id="tbxInsToolbox">
<menubar id="mbrInspectorMain"/>
<toolbar id="tbInspectorPrimary"/>
</toolbox>
<vbox id="bxInspectorMain" flex="1"/></code>
</pre>
<p>Il n'y a aucun menu, barres d'outils, etc. définies ici. Même la plupart des éléments qui ne sont pas visibles tels que <code><a href="/fr/XUL/keyset" title="en/XUL/keyset">key</a></code>- et <code><a href="/fr/XUL/commandset" title="en/XUL/commandset">commandset</a></code>, ne sont pas définis dans inspector.xul. Ils sont tirés d'une série d'overlays, afin que le XUL définissant l'interface de l’Inspecteur DOM puisse être organisé en unités discrètes. inspector.xul en lui-même n'est qu'un squelette définissant la structure et la disposition basique de la fenêtre principale de l'Inspecteur DOM, laissant ainsi la plupart de son contenu être ajouté par les overlays.</p>
<p>En utilisant des overlays modulaires permet également au XUL commun d'être partagé à travers les différents documents qui composent l'interface de l'Inspectreur DOM, même si toutes les overlays ne sont pas partagées par plusieurs utilisateurs. Il existe des overlays sur mesure uniquement pour des organisations.</p>
<p>Dans certains cas, les overlays sont surchargées par d'autres overlays. Si nous imaginons une structure d'arbre obtenue en connectant les overlays en tant qu'enfants des fichiers qu'elles "overlayent" tout en ignorant les overlays utilisées pour l'intégration hôte, nous pouvons alors visualiser l'arbre d'overlays pour un fichier donné. Voici l'arbre d'overlay étendu ne prenant pas en compte les overlays d'hôte pour inspector.xul :</p>
<ul>
<li><a class="external" rel="freelink">chrome://inspector/content/inspector.xul</a>
<ul>
<li><a class="external" rel="freelink">chrome://inspector/content/inspectorOverlay.xul</a></li>
<li><a class="external" rel="freelink">chrome://inspector/content/toolboxOverlay.xul</a></li>
<li><a class="external" rel="freelink">chrome://inspector/content/popupOverlay.xul</a>
<ul>
<li><a class="external" rel="freelink">chrome://inspector/content/editingOverlay.xul</a></li>
<li><a class="external" rel="freelink">chrome://inspector/content/viewers/d...pupOverlay.xul</a></li>
<li><a class="external" rel="freelink">chrome://inspector/content/viewers/s...pupOverlay.xul</a></li>
</ul>
</li>
<li><a class="external" rel="freelink">chrome://inspector/content/commandOverlay.xul</a>
<ul>
<li><a class="external" rel="freelink">chrome://inspector/content/viewers/d...andOverlay.xul</a></li>
</ul>
</li>
<li><a class="external" rel="freelink">chrome://inspector/content/keysetOverlay.xul</a>
<ul>
<li><a class="external" rel="freelink">chrome://inspector/content/viewers/d...setOverlay.xul</a></li>
</ul>
</li>
<li><a class="external" rel="freelink">chrome://inspector/content/statusbarOverlay.xul</a></li>
<li><a class="external" rel="freelink">chrome://global/content/globalOverlay.xul</a></li>
</ul>
</li>
</ul>
<p>(Il est à noter que les overlays des sous dossiers du viewer —viewers/dom et viewers/styleRules— sont chargés à la suite des <a href="/fr/Chrome_Registration#overlay" title="/en/chrome.manifest#overlay"><code>directives d'overlay</code></a> dans le manifeste chrome de l'Inspecteur DOM, au lieu d'être simplement importé explicitement en utilisant une instruction de processus <code>xul-overlay</code> dans l'overlay surchargée)</p>
<dl>
<dt>inspectorOverlay.xul</dt>
<dd>
<p>Ce fichier importe les scripts supérieurs, dont l'Inspecteur à besoin (cela inclut les dépendances). De plus, il définit le contenu du corps principal de la fenêtre de l'Inspecteur DOM c'est à dire : le panelset, les viewers documents et objets et le document du panneau du navigateur. (Le panneau du navigateur n'est pas un panneau viewer dans le sens ou les viewer document et objets eux le sont. C'est-à-dire les sortes de panneaux définis précédemment en relation avec le panelset. "panneau" est ici utilisé en fonction du panneau du navigateur dans un sens large pour décrire la mixture d'interface générique)</p>
</dd>
<dt>toolboxOverlay.xul</dt>
<dd>
<p>Cette overlay, remplit la boite à outils de l'Inspecteur, incluant les boutons de la barre d'outils et la "location bar" avec son bouton "inspect". toolboxOverlay.xul définit également la structure de menubar, sans pour autant définir le contenu des menus eux-mêmes.</p>
</dd>
<dt>popupOverlay.xul</dt>
<dd>
<p>Cette iverlay définit la plupart de la structure statique des menus dans le menubar, avec quelques exceptions. Pour des raisons évidentes, le contenu des menus dynamiques n’est pas défini ici. Les menus dynamiques comprennent les pop-up du menu Inspecter ("Inspect Content Document" et "Inspect Chrome Document") du menu fichier, et les menus "Document Viewer" et "Object Viewer" du menu View. La préférence menuitems dans le menu View qui affecte uniquement le viewer de noeuds DOM ("Blink Selected Element", etc..) sont ajouté par l'overlay de pop-up de ce viewer (resources/content/viewers/dom/popupOverlay.xul). C'est également vrai pour les menuitems Find et le menuitem "Select Element By Click" dans le menu Edit, car aucun viewer à part le viewer de noeuds DOM ne supporte ces features.</p>
<p>Les autres objets du menu Edit sont également utilisés dans plusieurs menus contextuels de viewers. Pour cette raison, seuls les id des menuitems sont référencés ici, et les difinitions complètes sont importées depuis editingOverlay.xul. Les viewers qui incluent un ou plus de ces menuitems dans leu contexte suivent la même pratique.</p>
<p>Le tooltip utilisé pour les menus Inspect—Celui utilisé pour afficher le titre d'un document et son URI pour un menuitme donné--est également défini ici.</p>
</dd>
<dt>commandOverlay.xul</dt>
<dd>Les menuitems fournis par popupOverlay.xul qui délèguent à des éléments de <code><a href="/fr/XUL/command" title="en/XUL/command">command</a></code> externe ont leurs commandes définies ici.</dd>
<dt>keysetOverlay.xul</dt>
<dd>Certains menutimes fournis par popupOverlay.xul ont leurs <code><a href="/fr/XUL/key" title="en/XUL/key">keys</a></code> définis ici. Au moment présent, toutes les clés qui correspondent aux objets du menu Edit sont dans editingOverlay sans aucune bonne raison.</dd>
<dt>statusbarOverlay.xul</dt>
<dd>Ce fichier définit le contenu de la barre de statuts de l'Inspecteur DOM. L'Inspecteur DOM n'ayant pas de barre de statut, ce fichier est complètement inutile.</dd>
</dl>
|