Firefox 8 pour les développeurs

  1. Notes de versions pour développeurs
    1. Notes de versions pour développeurs
  2. Modules complémentaires
    1. WebExtensions
    2. Thèmes
  3. Fonctionnement interne de Firefox
    1. Le projet Mozilla
    2. Gecko
    3. Mode « headless »
    4. Modules de code Javascript
    5. JS-ctypes
    6. Le projet MathML
    7. MFBT
    8. Les projets Mozilla
    9. Le système de préférences
    10. Connexions WebIDL
    11. XPCOM
    12. XUL
  4. Développer et contribuer
    1. Instructions de compilation
    2. Configuration des options de compilation
    3. Fonctionnement de la compilation
    4. Code source de Mozilla
    5. Localisation
    6. Mercurial
    7. Assurance qualité
    8. Utilisation de code Mozilla dans d'autres projets

Firefox 8, basé sur Gecko 8.0, est sorti le 8 novembre 2011. Cet article fournit des informations à la fois pour les developpeurs Web et pour les développeurs d'extensions et de projets liés à Mozilla pour aider à tirer pleinement parti des fonctionnalités de cette version.

Changements pour les développeurs Web

HTML

  • La propriété crossOrigin a été ajouté à HTMLImageElement et l'attribut crossorigin a été ajouté à l'élément <img> (voir bug 664299).
  • La méthode HTMLSelectElement.add() supporte désormais supporte désormais soit un élément ou soit l'index d'un élément auquel un nouvel élément doit être inséré avant. Auparavant, seulement un élément était supporté (voir bug 666200).
  • Le constructeur HTMLIsIndexElement a été retiré. Aucun éléments n'a implémenté cette interface depuis Firefox 4.
  • la fonctionnalité HTML5 "menu contextuel" (attribut contextmenu), qui vous permet d'ajouter des éléments personnalisés particuliers au menu contextuel d'origine, est désormais supportée (l'implémentation est encore expérimentale en attendant des changements dans la spécification (voir bug 617528).
  • Le support de l'attribut accesskeylabel a été ajouté à tous les éléments.
  • les éléments <input> et <textarea> supportent désormais l'attribut selectionDirection, et leurs méthodes setSelectionRange() ont été mises à jour pour supporter éventuellement la spécification d'une direction.
  • La plupart des éléments peuvent désormais obtenir une bague de focalisation établie autour d'eux s'ils ont été faits pouvant recevoir le focus via l'attribut tabindex et que l'utilisateur se concentre ensuite sur l'élément.
  • Dans un ensemble d'éléments <label> imbriqués, cliquer sur les événements ne déclencheront plus plusieurs éléments, qui, avant, provoquaient un blocage de Firefox (voir bug 646157).

DOM

  • La méthode insertAdjacentHTML a été implémentée.
  • BlobBuilder dispose désormais d'une méthode getFile() qui renvoie le contenu du blob dans un fichier.
  • L'interface FileReaderSync (partie de FileAPI) a été implementée.
  • La gestion des évènements par les <label> imbriqués a été fixée.
  • Vous pouvez maintenant utiliser window.postMessage() pour passer les objets File et FileList entre les fenêtres.
  • Lors de l'édition de zones element.contenteditable la sortie d'une position en appuyant sur retour, ou à la sortie d'une liste en mode édition en appuyant sur retour à deux reprises, revient maintenant au mode d'entrée au paragraphe (c'est-à-dire les paragraphes à l'intérieur des blocs <p>) au lieu de lignes de séparation par les éléments <br>.
  • Correction d'un bug empêchant la justification de la prise d'effet correcte lorsqu'elle est appliquée à la première ligne dans une zone element.contenteditable.
  • Correction d'un bug qui faisait que en appuyant sur Suppr ou Retour arrière au début d'une zone element.contenteditable affectait le bloc contenteditable précédent s'il était présent.
  • document.getSelection() renvoie désormais l'objet Selection identique à window.getSelection(), à la place de stringifying.
  • La propriété HTML5 selectionDirection permet de définir la direction de la sélection dans un texte éditable.
  • HTMLMediaElement a maintenant une propriété seekable qui retourne l'objet TimeRanges.
  • L'attribut .preload de HTMLMediaElement se reflète désormais comme une valeur énumérée.
  • Les propriétés crossOrigin sont par défaut defaults to "Anonyme" quand une valeur invalide est utilisée.
  • window.navigator.cookieEnabled renvoie désormais correctement l'information quand le paramètre de cookie par défaut est écrasé sur la base de chaque site.

JavaScript

  • RegExp.exec() et RegExp.test() appelés sans arguments correspondent maintenant à la chaîne "undefined".
  • String.search() et String.match() appelés sans arguments ou undefined correspondent désormais à une chaîne vide et correspondent donc à chaque chaîne.
  • Le support des listes de surveillance a été implémenté avec les nouvelles mtéhodes (non standards) watch() et unwatch().

CSS

  • resolution accepte désormais <number>, pas seulement des valeurs <integer> comme avec la spécification.
  • Les règles de césure ont été ajoutées pour de nombreuses nouvelles langues lors de l'utilisation de hyphens.
  • Le traitement de background-size a été revu pour mieux correspondre à la spécification.
  • Dans le passé, text-decoration en mode quirks avait l'épaisseur de ligne et la position ajustée sur le texte descendant pour correspondre à la descendance. Désormais le mode standard et le mode quirks ont un rendu plus proche.
  • Le positionnement horizontal des éléments est davantage conforme à la spécification dans beaucoup de cas. La documentation est à venir, mais pour l'instant, pour plus de détails voir le commentaire 23 du bug 682780.
  • Les images SVG sont désormais correctement mise à l'échelle lorsqu'elles sont utilisées comme images de fond.

Réseau

  • Les doubles guillemets ne sont plus acceptés en tant que délimiteur pour l'encodage RFC 2231 ou RFC 5987, conformément à ces RFCs.
  • Le parseur MIME du champ d'en-tête (Content-Disposition) exige désormais "=" dans les paramètres.
  • Les scripts ne sont plus téléchargés lorsque JavaScript est désactivé.
  • SSL 2.0 n'est plus supporté.

WebSockets

  • La méthode send() de l'objet WebSocket ne renvoie plus à tort une valeur booléenne.
  • La méthode close() de l'objet WebSocket correspond désormais à la version actuelle du standard, et les événements proches utilisent à présent correctement l'interface CloseEvent.
  • L'attribut extensions de l'objet WebSocket est à présent supporté.
  • Le constructeur WebSocket supporte désormais un ensemble de protocoles ainsi que la chaîne d'un seul protocole.
  • Le contenu mixte n'est pas autorisé avec WebSockets, vous ne pouvez plus établir une connexion vers un serveur WebSocket non sécurisé à partir d'un contenu sécurisé.
  • Les erreurs de connexion avec WebSockets déclenchent à présent le gestionnaire onerror.
  • L'API WebSocket a été mise à jour suivant la dernière version de la spécification (voir bug 674890, bug 674527 et bug 674716).
  • L'extension deflate-stream pour WebSockets a été désactivée, elle est obsolète et a cassée la compatibilité avec quelques sites.

WebGL

  • Les textures Cross-domain sont à présent autorisées avec l'accord de CORS.
  • Le processus de rendu Cross avec Direct2D/Direct3D 10.

MathML

  • le support de l'attribut displaystyle sur l'élément de premier niveau <math> a été ajouté.
  • L'interprétation de numéros de lignes négatifs pour l'attribut align de <mtable> a été corrigée.

Outils de développement

  • L'objet console a une nouvelle méthode dir(), qui affiche une liste interactive des propriétés sur un objet spécifié.

Changements pour les développeurs de Mozilla et de modules complémentaires

Voir Updating add-ons for Firefox 8 pour vous guidez dans les modifications que vous êtes susceptibles d'avoir à faire pour rendre vos extensions compatibles avec Firefox 8.

Note : Firefox 8 requiert que les composants binaires soient recompilés, comme pour toutes les versions majeures de Firefox. Pour plus de détails, voir Interfaces Binaires.

XPCOM

Components.utils

Les nouvelles méthodes Components.utils.createObjectIn() et Components.utils.makeObjectPropsNormal() ont été créées pour faciliter la création d'objets dans des compartiments spécifiques.

Autres changements relatifs à XPCOM

  • Vous pouvez à présent demander des objets DOM File à partir d'éléments du code en faisant simplement un nouveau fichier, au lieu de devoir demander directement à nsIDOMFile.
  • Le type de tableau nsTPtrArray a été retiré. La fonctionnalité est désormais disponible sur tous les nsTArray, qui propose désormais la méthode SafeElementAt() lors d'une demande à l'aide d'un type de pointeur. Voir la section sur SafeElementAt() dans le guide des tableaux XPCOM pour plus de détails.

Workers

Il n'est plus possible d'accéder à des objets XPCOM depuis ChromeWorkers. XPConnect a été désactivé dans le contexte des travailleurs comme indiqué par le bug 649537.

XUL

Changements dans le système de compilation

  • Les options de configuration de compilation suivantes ont été retirées :
    • --enable-timeline
    • --disable-storage
    • --necko-disk-cache
  • Lors de la compilation des fichiers IDL aux en-têtes, le fichier d'en-tête jspubtd.h est automatiquement inclus lorsque c'est nécessaire. L'inclusion manuelle de jspubtd.h et/ou jsapi.h dans des fichiers IDL qui utilisent jsval ou [implicit_jscontext] n'est plus nécessaire.

Enregistrement du chrome

  • L'indicateur platformversion peut être utilisé dans le chrome.manifest pour spécifier la compatibilité entre les versions de Gecko.

Changements dans les interfaces

  • La méthode mozIJSSubScriptLoader.loadSubScript() charge désormais scripts à partir du cache de démarrage lorsque c'est possible.
  • L'attribut ownerWindow a été supprimé de l'interface nsIAccessNode.
  • L'interface nsIDOMStorageWindow a été fusionnée avec l'interface nsIDOMWindow.
  • Tous les membres de l'interface nsIDOMWindowInternal ont été déplacés dans l'interface nsIDOMWindow. L'interface (sans les membres) reste disponible pour la compatibilité jusqu'à Firefox 9.
  • Afin d'améliorer les performances, le rappel pour les mises à jour asynchrones des bases de données Places a été changé. Voir les nouvelles méthodes mozIVisitInfoCallback.handleResult() et mozIVisitInfoCallback.handleError(), qui remplacent l'ancienne unique méthode pour les erreurs et les conditions de succès.
  • L'attribut KIND_MAPPED de nsIMemoryReporter a été désapprouvé au profit de KIND_NONHEAP, de nouveaux types d'unités ont été ajoutées : UNITS_COUNT_CUMULATIVE et UNITS_PERCENTAGE.
  • L'interface nsIMemoryReporterManager a un nouvel attribut explicit, qui indique explicitement la taille totale des allocations de mémoire.
  • L'interface nsIMemoryReporterManager a un nouvel attribut resident, qui relève la quantité de mémoire physique utilisée.
  • L'interface nsINetworkLinkService a un nouvel attribut, linkType. Cet attribut indique le type de connexion réseau en cours d'utilisation. Tous les systèmes d'exploitation retournent actuellement LINK_TYPE_UNKNOWN. Le support d'Android a été gardé pour des raisons de sécurité.
  • L'interface nsISelection2 a été fusionnée avec l'interface nsISelectionPrivate.
  • L'interface nsISelection3 a été fusionnée avec l'interface nsISelection.
  • L'attribut state de nsISessionStartup est désormais de type jsval au lieu d'être une chaîne, pour des raisons de performance.
  • L'état de l'attribut isActive de (nsIDocShell) est désormais false pour les fenêtres minimisées.
  • La méthode nsIDownloadHistory.addDownload() enregistre désormais la cible de l'endroit où le téléchargement est sauvegardé, sur le système de fichiers local.

Interfaces supprimées

Les interfaces suivantes ont été supprimées car elles n'étaient plus indispensables :

  • nsITimelineService
  • nsIDOMHTMLIsIndexElement

L'interface nsIWorkerFactory a également été retirée. WLes travailleurs peuvent encore être créés à l'aide des constructeurs Worker et ChromeWorker.

Autres changements

  • Quand une fenêtre est minimisée (non réduite), ou basculée entre le plein écran et le mode fenêtré, elle reçoit l'événement sizemodechange.
  • You can now la préférence extensions.autoDisableScopes pour désactiver l'installation automatique d'extensions sur un emplacement d'installation.
  • La nouvelle propriété document.mozSyntheticDocument des objets Document vous permet de déterminer si un document est synthétique (comme une image, une vidéo ou un fichier audio) plutôt qu'un document DOM standard. Cela peut être utile, par exemple, si vous voulez présenter une interface utilisateur différente dans cette situation (comme l'ajout d'éléments contextuels différemment selon le cas présent).
  • Vous pouvez désormais spécifier un filtre en ouvrant about:config ; par exemple, "about:config?filter=sessionstore" n'affichera que les préférences liées au stockage des sessions.

Voir aussi