Maison interface Web js tutoriel Différences entre js dans IE et les connaissances Firefox_Basic

Différences entre js dans IE et les connaissances Firefox_Basic

May 16, 2016 pm 04:31 PM
firefox ie js

1.firefox ne peut pas prendre en charge innerText.
Firefox prend en charge innerHTML mais pas innerText. Il prend en charge textContent pour implémenter innerText, mais les espaces supplémentaires sont également conservés par défaut. Si textContent n'est pas utilisé, innerHTML peut être utilisé à la place si la chaîne ne contient pas de code HTML.

2. Interdire la sélection de contenu Web :
Utilisez généralement js dans IE : obj.onselectstart=function(){return false;}
Firefox utilise CSS :-moz-user-select:none

3. Support de filtre (exemple : filtre transparent) :
IE:filter:alpha(opacity=10);
firefox:-moz-opacity:.10;

4. Capturer l'événement :
IE : obj.setCapture(), obj.releaseCapture()
Firefox : document.addEventListener("mousemove",mousemovefunction,true);
document.removeEventListener("mousemove",mousemovefunction,true);

5. Obtenez la position de la souris :
IE : event.clientX, event.clientY
Firefox : la fonction événementielle est requise pour transmettre l'objet événement
obj.onmousemove=fonction(ev){
X=ev.pageX;Y=ev.pageY;
>

6. Problèmes de limites du DIV et d'autres éléments :
Par exemple : définissez le CSS d'un div ::{width:100px;height:100px;border:#000000 1px solid;}
Dans IE : largeur du div (largeur de la bordure incluse) : 100 px, hauteur du div (largeur de la bordure incluse) : 100 px ; Et firefox : la largeur du div (y compris la largeur de la bordure) : 102px, la hauteur du div (y compris la largeur de la bordure) : 102px
;

Ainsi, lorsque vous créez cette fenêtre glissante compatible avec IE et Firefox, vous devez utiliser votre cerveau pour écrire du js et du css. Voici deux conseils pour vous

.

1. Déterminez le type de navigateur :

var isIE=document.all? true:false;
J'ai écrit une variable, si la syntaxe document.all est prise en charge alors isIE=true, sinon isIE=false

2. Traitement CSS sous différents navigateurs :

Généralement, vous pouvez utiliser !important pour prioriser l'utilisation des instructions CSS (uniquement pris en charge par Firefox)
Par exemple : {border-width:0px!important;border-width:1px;}
Sous Firefox, cet élément n'a pas de bordure. Sous IE, la largeur de la bordure est de 1px
.

Problème 1.document.formName.item("itemName")

Description du problème : Sous IE, vous pouvez utiliser document.formName.item("itemName") ou document.formName.elements ["elementName"] sous Firefox, vous ne pouvez utiliser que document.formName.elements["elementName"] ; .
Solution : utilisez document.formName.elements["elementName"] uniformément.

2. Problème d'objet de collection

Description du problème : Sous IE, vous pouvez utiliser () ou [] pour obtenir des objets de collection ; sous Firefox, vous ne pouvez utiliser que [ ] pour obtenir des objets de collection.
Solution : utilisez [] uniformément pour obtenir des objets de classe de collection.

3. Problèmes d'attributs personnalisés

Description du problème : sous IE, vous pouvez utiliser la méthode d'obtention d'attributs normaux pour obtenir des attributs personnalisés, ou vous pouvez utiliser getAttribute() pour obtenir des attributs personnalisés ; sous Firefox, vous ne pouvez utiliser getAttribute() que pour obtenir des attributs personnalisés.
Solution : Obtenez uniformément des attributs personnalisés via getAttribute().

Problème 4.eval("idName")

Description du problème : Sous IE, vous pouvez utiliser eval("idName") ou getElementById("idName") pour récupérer l'objet HTML avec l'identifiant idName ; sous Firefox, vous ne pouvez utiliser que getElementById("idName") pour récupérer le Objet HTML avec l'identifiant idName .
Solution : utilisez getElementById("idName") uniformément pour obtenir l'objet HTML dont l'identifiant est idName.

5. Le problème est que le nom de la variable est le même qu'un identifiant d'objet HTML

Description du problème : Sous IE, l'ID de l'objet HTML peut être utilisé directement comme nom de variable de l'objet subordonné du document, mais pas sous Firefox, sous Firefox, le même nom de variable que l'ID de l'objet HTML peut être utilisé, mais pas sous IE.
Solution de contournement : utilisez document.getElementById("idName") au lieu de document.idName. Il est préférable de ne pas utiliser de noms de variables avec le même ID d'objet HTML pour réduire les erreurs ; lors de la déclaration des variables, ajoutez toujours le mot-clé var pour éviter toute ambiguïté.

6.problème de const

Description du problème : Sous Firefox, vous pouvez utiliser le mot-clé const ou le mot-clé var pour définir des constantes ; sous IE, vous ne pouvez utiliser que le mot-clé var pour définir des constantes.
Solution : utilisez le mot-clé var uniformément pour définir des constantes.

Problème d'attribut 7.input.type

Description du problème : L'attribut input.type sous IE est en lecture seule ; mais l'attribut input.type sous Firefox est en lecture-écriture.
Solution : Ne modifiez pas l'attribut input.type. Si vous devez le modifier, vous pouvez d'abord masquer l'entrée d'origine, puis insérer un nouvel élément d'entrée à la même position.

Problème 8.window.event

Description du problème : window.event ne peut être exécuté que sous IE, pas sous Firefox. En effet, l'événement de Firefox ne peut être utilisé que sur la scène où l'événement se produit.
Solution : ajoutez le paramètre d'événement à la fonction où l'événement se produit et utilisez var myEvent = evt?evt:(window.event?window.event:null)
dans le corps de la fonction (en supposant que le paramètre formel est evt) Exemple :

Copier le code Le code est le suivant :

function faireQuelquechose(evt) {
var monEvénement = evt?evt:(window.event?window.event:null)
...
>


9.Problèmes Event.x et event.y Description du problème : Sous IE, l'objet pair a les attributs x et y, mais pas d'attributs pageX et pageY ; sous Firefox, l'objet pair a les attributs pageX et pageY, mais pas d'attributs x et y.

Solution : var myX = event.x ? event.x : event.pageX; var myY = event.y:event.pageY;
Si vous considérez la question 8, utilisez simplement myEvent au lieu de event.

Problème 10.event.srcElement

Description du problème : Sous IE, l'objet pair a l'attribut srcElement, mais pas l'attribut target ; sous Firefox, l'objet pair a l'attribut target, mais il n'y a pas d'attribut srcElement.

Solution : utilisez srcObj = event.srcElement ? event.srcElement : event.target;
Si vous considérez la question 8, utilisez simplement myEvent au lieu de event.

Problème 11.window.location.href

Description du problème : Sous IE ou Firefox2.0.x, vous pouvez utiliser window.location ou window.location.href ; sous Firefox1.5.x, vous ne pouvez utiliser que window.location.

Solution de contournement : utilisez window.location au lieu de window.location.href. Bien entendu, vous pouvez également envisager d’utiliser la méthode location.replace().

12. Problèmes de fenêtre modale et non modale

Description du problème : Sous IE, les fenêtres modales et non modales peuvent être ouvertes via showModalDialog et showModelessDialog, mais cela ne peut pas être fait sous Firefox ;

Solution : utilisez directement window.open(pageURL,name,parameters) pour ouvrir une nouvelle fenêtre.
Si vous devez transmettre les paramètres de la fenêtre enfant à la fenêtre parent, vous pouvez utiliser window.opener dans la fenêtre enfant pour accéder à la fenêtre parent. Si vous avez besoin de la fenêtre parent pour contrôler la fenêtre enfant, utilisez var subWindow = window.open(pageURL,name,parameters); pour obtenir l'objet fenêtre nouvellement ouvert.

13.Problèmes de cadre et d'iframe

Prenons comme exemple le cadre suivant :

(1) Accéder à l'objet cadre
IE : utilisez window.frameId ou window.frameName pour accéder à cet objet frame
Firefox : utilisez window.frameName pour accéder à cet objet frame
Solution : utilisez window.document.getElementById("frameId") uniformément pour accéder à cet objet frame
;
(2) Changer le contenu du cadre
Dans IE et Firefox, vous pouvez utiliser window.document.getElementById("frameId").src = "xxx.html" ou window.frameName.location = "xxx.html" pour changer le contenu du cadre

Si vous devez transmettre les paramètres du cadre à la fenêtre parent, vous pouvez utiliser le mot-clé parent dans le cadre pour accéder à la fenêtre parent.


14.problème de chargement du corps
Description du problème : l'objet body de Firefox existe avant que la balise body ne soit entièrement lue par le navigateur ; tandis que l'objet body d'IE doit exister après que la balise body soit entièrement lue par le navigateur.

​​​[Note] Ce problème n'a pas été réellement vérifié et sera modifié après vérification.

[Note] Il a été vérifié que le problème ci-dessus n'existe pas dans IE6, Opera9 et FireFox2. Un simple script JS peut accéder à tous les objets et éléments qui ont été chargés avant le script, même si l'élément n'a pas encore été chargé.

15. Méthode de délégation d'événement
Description du problème : Sous IE, utilisez document.body.onload = inject ; là où la fonction inject() a déjà été implémentée sous Firefox, utilisez document.body.onload = inject();

 ; Solution : Utilisez document.body.onload=new Function('inject()'); ou document.body.onload = function(){/* Voici le code */}

         [Remarque] La différence entre fonction et fonction

16. Différences dans les éléments parents accessibles
Description du problème : Sous IE, utilisez obj.parentElement ou obj.parentNode pour accéder au nœud parent d'obj ; sous Firefox, utilisez obj.parentNode pour accéder au nœud parent d'obj.

Solution : étant donné que Firefox et IE prennent en charge DOM, obj.parentNode est utilisé uniformément pour accéder au nœud parent d'obj.


17.cursor:main VS curseur:pointeur
Description du problème : Firefox ne prend pas en charge la main, mais IE prend en charge le pointeur. Les deux sont des instructions manuelles.

Solution : utilisez le pointeur de manière uniforme.


18.Problème de texte intérieur
Description du problème : innerText fonctionne normalement dans IE, mais innerText ne fonctionne pas dans FireFox.

Solution : utilisez textContent au lieu de innerText dans les navigateurs non IE.

Exemple :



Copier le code Le code est le suivant :

if(navigator.appName.indexOf("Explorer") >-1){
document.getElementById('element').innerText = "mon texte"
} autre{
document.getElementById('element').textContent = "mon texte"
}

[Remarque] innerHTML est pris en charge par les navigateurs tels que IE et Firefox en même temps. D'autres, tels que externalHTML, ne sont pris en charge que par IE et il est préférable de ne pas les utiliser.

19. Problème d'attribution de largeur et de hauteur d'objet
Description du problème : les instructions telles que obj.style.height = imgObj.height ne sont pas valides dans FireFox.
Solution : utilisez obj.style.height = imgObj.height 'px';

20. Problèmes de fonctionnement de la table
Description du problème : IE, Firefox et d'autres navigateurs ont des opérations différentes sur les balises de table. Dans IE, l'affectation innerHTML de table et tr n'est pas autorisée. Lorsque vous utilisez js pour ajouter un tr, la méthode appendChild ne fonctionne pas.
Solution :

Copier le code Le code est le suivant :

//Ajouter une ligne vide au tableau :
var row = otable.insertRow(-1);
var cell = document.createElement("td");
cellule.innerHTML = "";
cellule.className = "XXXX" ;
row.appendChild(cellule);

[Note] Comme j'utilise rarement JS pour faire fonctionner directement des tables, je n'ai jamais rencontré ce problème. Il est recommandé d'utiliser le framework JS pour faire fonctionner des tables, telles que JQuery.

21. Problème d'indentation des listes ul et ol
Lors de l'élimination de l'indentation de listes telles que ul et ol, le style doit être écrit comme suit : list-style:none;margin:0px;padding:0px
L'attribut margin est valide pour IE et l'attribut padding est valide pour FireFox. ← Cette phrase est mal exprimée, voir ↓
pour plus de détails ​​​[Note] Ce problème n'a pas été réellement vérifié et sera modifié après vérification.
[Note] Il a été vérifié que dans IE, la définition de margin:0px peut supprimer les retraits supérieurs, inférieurs, gauche et droit, les espaces et les numéros ou points de liste de la liste. La définition du remplissage n'a aucun effet sur le style dans Firefox ; la définition de margin:0px ne peut supprimer que les retraits supérieur et inférieur. Après avoir défini padding:0px, vous ne pouvez supprimer que les retraits gauche et droit. Vous devez également définir list-style:none pour supprimer les numéros de liste ou les points. En d'autres termes, dans IE, seul margin:0px peut être défini pour obtenir l'effet final, tandis que dans Firefox, margin:0px, padding:0px et list-style:none doivent être définis en même temps pour obtenir l'effet final.

22. Problème de transparence CSS
IE : filtre:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60).
FF : opacité : 0,6.
​​​[Note] Il est préférable d'écrire les deux et de mettre l'attribut d'opacité ci-dessous.

23. Problème de coins arrondis CSS
IE : les versions inférieures à ie7 ne prennent pas en charge les coins arrondis.
FF : -moz-border-radius:4px, ou -moz-border-radius-topleft:4px;-moz-border-radius-topright:4px;-moz-border-radius-bottomleft:4px;-moz-border- rayon en bas à droite : 4 px ;.
[Note] Le problème des coins arrondis est un problème classique en CSS. Il est recommandé d'utiliser le jeu de cadres JQuery pour définir les coins arrondis et de laisser ces problèmes complexes à d'autres.

Il y a trop de problèmes en CSS, et même la même définition CSS a des effets d'affichage différents selon les normes de page. Une suggestion qui convient au développement est que la page soit écrite en utilisant le standard DHTML, avec moins d'utilisation de tableaux, et que les définitions CSS soient basées autant que possible sur le DOM standard, en tenant compte des navigateurs grand public tels que IE, Firefox et Opéra. BTW, dans de nombreux cas, les normes d'interprétation CSS de FF et Opera sont plus proches des normes CSS et plus normatives.

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser JS et Baidu Maps pour implémenter la fonction Map Pan Comment utiliser JS et Baidu Maps pour implémenter la fonction Map Pan Nov 21, 2023 am 10:00 AM

Comment utiliser JS et Baidu Map pour implémenter la fonction de panoramique de la carte Baidu Map est une plate-forme de services cartographiques largement utilisée, souvent utilisée pour afficher des informations géographiques, le positionnement et d'autres fonctions dans le développement Web. Cet article explique comment utiliser JS et l'API Baidu Map pour implémenter la fonction de panoramique de la carte et fournit des exemples de code spécifiques. 1. Préparation Avant d'utiliser l'API Baidu Map, vous devez d'abord demander un compte de développeur sur Baidu Map Open Platform (http://lbsyun.baidu.com/) et créer une application. Création terminée

Comment supprimer Firefox Snap dans Ubuntu Linux ? Comment supprimer Firefox Snap dans Ubuntu Linux ? Feb 21, 2024 pm 07:00 PM

Pour supprimer FirefoxSnap dans UbuntuLinux, vous pouvez suivre ces étapes : Ouvrez un terminal et connectez-vous à votre système Ubuntu en tant qu'administrateur. Exécutez la commande suivante pour désinstaller FirefoxSnap : sudosnapremovefirefox Vous serez invité à saisir votre mot de passe administrateur. Entrez votre mot de passe et appuyez sur Entrée pour confirmer. Attendez la fin de l’exécution de la commande. Une fois terminé, FirefoxSnap sera complètement supprimé. Notez que cela supprimera les versions de Firefox installées via le gestionnaire de packages Snap. Si vous avez installé une autre version de Firefox par d'autres moyens (tels que le gestionnaire de packages APT), vous ne serez pas affecté. Suivez les étapes ci-dessus

Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Apr 03, 2024 am 11:55 AM

La technologie de détection et de reconnaissance des visages est déjà une technologie relativement mature et largement utilisée. Actuellement, le langage d'application Internet le plus utilisé est JS. La mise en œuvre de la détection et de la reconnaissance faciale sur le front-end Web présente des avantages et des inconvénients par rapport à la reconnaissance faciale back-end. Les avantages incluent la réduction de l'interaction réseau et de la reconnaissance en temps réel, ce qui réduit considérablement le temps d'attente des utilisateurs et améliore l'expérience utilisateur. Les inconvénients sont les suivants : il est limité par la taille du modèle et la précision est également limitée ; Comment utiliser js pour implémenter la détection de visage sur le web ? Afin de mettre en œuvre la reconnaissance faciale sur le Web, vous devez être familier avec les langages et technologies de programmation associés, tels que JavaScript, HTML, CSS, WebRTC, etc. Dans le même temps, vous devez également maîtriser les technologies pertinentes de vision par ordinateur et d’intelligence artificielle. Il convient de noter qu'en raison de la conception du côté Web

Comment créer un graphique en chandeliers boursiers en utilisant PHP et JS Comment créer un graphique en chandeliers boursiers en utilisant PHP et JS Dec 17, 2023 am 08:08 AM

Comment utiliser PHP et JS pour créer un graphique en bougies boursières. Un graphique en bougies boursières est un graphique d'analyse technique courant sur le marché boursier. Il aide les investisseurs à comprendre les actions de manière plus intuitive en dessinant des données telles que le prix d'ouverture, le prix de clôture, le prix le plus élevé et le prix le plus élevé. prix le plus bas des fluctuations du prix des actions. Cet article vous apprendra comment créer des graphiques en bougies boursières en utilisant PHP et JS, avec des exemples de code spécifiques. 1. Préparation Avant de commencer, nous devons préparer l'environnement suivant : 1. Un serveur exécutant PHP 2. Un navigateur prenant en charge HTML5 et Canvas 3.

Outils essentiels pour l'analyse boursière : découvrez les étapes pour dessiner des graphiques en bougies avec PHP et JS Outils essentiels pour l'analyse boursière : découvrez les étapes pour dessiner des graphiques en bougies avec PHP et JS Dec 17, 2023 pm 06:55 PM

Outils essentiels pour l'analyse boursière : découvrez les étapes pour dessiner des graphiques en bougies en PHP et JS. Des exemples de code spécifiques sont nécessaires. Avec le développement rapide d'Internet et de la technologie, le trading d'actions est devenu l'un des moyens importants pour de nombreux investisseurs. L'analyse boursière est une partie importante de la prise de décision des investisseurs, et les graphiques en bougies sont largement utilisés dans l'analyse technique. Apprendre à dessiner des graphiques en bougies à l'aide de PHP et JS fournira aux investisseurs des informations plus intuitives pour les aider à prendre de meilleures décisions. Un graphique en chandeliers est un graphique technique qui affiche les cours des actions sous forme de chandeliers. Il montre le cours de l'action

Comment utiliser JS et Baidu Map pour implémenter la fonction de traitement des événements de clic sur la carte Comment utiliser JS et Baidu Map pour implémenter la fonction de traitement des événements de clic sur la carte Nov 21, 2023 am 11:11 AM

Présentation de la façon d'utiliser JS et Baidu Maps pour implémenter les fonctions de traitement des événements de clic sur la carte : dans le développement Web, il est souvent nécessaire d'utiliser des fonctions de carte pour afficher la localisation géographique et les informations géographiques. Le traitement des événements de clic sur la carte est une partie couramment utilisée et importante de la fonction de carte. Cet article explique comment utiliser JS et l'API Baidu Map pour implémenter la fonction de traitement des événements de clic de la carte et donne des exemples de code spécifiques. Étapes : Importez le fichier API de Baidu Map. Tout d’abord, importez le fichier de l’API Baidu Map dans le fichier HTML. Cela peut être réalisé via le code suivant :

Que dois-je faire si Win11 ne peut pas utiliser le navigateur ie11 ? (win11 ne peut pas utiliser le navigateur IE) Que dois-je faire si Win11 ne peut pas utiliser le navigateur ie11 ? (win11 ne peut pas utiliser le navigateur IE) Feb 10, 2024 am 10:30 AM

De plus en plus d'utilisateurs commencent à mettre à niveau le système Win11. Étant donné que chaque utilisateur a des habitudes d'utilisation différentes, de nombreux utilisateurs utilisent toujours le navigateur ie11. Alors, que dois-je faire si le système Win11 ne peut pas utiliser le navigateur ie ? Windows11 prend-il toujours en charge ie11 ? Jetons un coup d'œil à la solution. Solution au problème selon lequel Win11 ne peut pas utiliser le navigateur ie11 1. Tout d'abord, cliquez avec le bouton droit sur le menu Démarrer et sélectionnez « Invite de commandes (administrateur) » pour l'ouvrir. 2. Après ouverture, entrez directement « Netshwinsockreset » et appuyez sur Entrée pour confirmer. 3. Après confirmation, entrez « netshadvfirewallreset&rdqu ».

Comment utiliser JS et Baidu Maps pour implémenter la fonction de carte thermique de carte Comment utiliser JS et Baidu Maps pour implémenter la fonction de carte thermique de carte Nov 21, 2023 am 09:33 AM

Comment utiliser JS et Baidu Maps pour implémenter la fonction de carte thermique de carte Introduction : Avec le développement rapide d'Internet et des appareils mobiles, les cartes sont devenues un scénario d'application courant. En tant que méthode d'affichage visuel, les cartes thermiques peuvent nous aider à comprendre la distribution des données de manière plus intuitive. Cet article explique comment utiliser JS et l'API Baidu Map pour implémenter la fonction de carte thermique de carte et fournit des exemples de code spécifiques. Travail de préparation : Avant de commencer, vous devez préparer les éléments suivants : un compte développeur Baidu, créer une application et obtenir l'AP correspondant

See all articles