Maison interface Web js tutoriel Solutions frontales Web aux problèmes de compatibilité des navigateurs

Solutions frontales Web aux problèmes de compatibilité des navigateurs

Mar 14, 2018 pm 01:36 PM
web 兼容性

Cette fois, je vous apporte la solution du front-end web au problème de compatibilité du navigateur. Quelles sont les précautions pour le front-end web pour résoudre le problème de compatibilité du navigateur. Voici les cas pratiques. jetez un oeil.

Le soi-disant problème de compatibilité des navigateurs fait référence à la situation dans laquelle différents navigateurs ont des interprétations différentes du même morceau de code, ce qui entraîne des effets d'affichage de page incohérents. Dans la plupart des cas, notre exigence est que quel que soit le navigateur utilisé par l'utilisateur pour consulter notre site Web ou se connecter à notre système, il doit y avoir un effet d'affichage unifié. Par conséquent, les problèmes de compatibilité des navigateurs sont des problèmes que les développeurs front-end rencontrent souvent et doivent résoudre :

1 css3media querySolution de compatibilité : Respond.js

Adresse GitHub : https://github.com/scottjehl/Respond
(depuis Internet)
IE8 ne prend pas en charge les requêtes multimédias CSS, ce qui nuit grandement au design réactif. Respond.js peut aider IE6-8 à être compatible avec les conditions de requête multimédia « min/max-width ».

Utilisation : référencez Respond.js après l'emplacement de référence de tous les fichiers CSS dans la page. Et plus Respond.js est référencé tôt, moins l'utilisateur a de chances de voir la page scintiller.

2. 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, les attributs personnalisés ne peuvent être obtenus qu'en utilisant getAttribute().
Solution : obtenez des attributs personnalisés via getAttribute().

3. Le problème que le nom de la variable est le même que l'ID en HTML

Description du problème : Sous IE, l'ID de l'objet HTML peut être utilisé directement comme nom de variable du objet subordonné du document, mais pas sous Firefox ; Firefox Sous IE, vous pouvez utiliser le même nom de variable que l'ID de l'objet HTML, mais pas sous IE.
Solution : 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é.

4. Problème 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é const. Mot-clé var pour définir des constantes.
Solution : utilisez le mot-clé var uniformément pour définir des constantes. Concernant const, qui est une méthode de définition de variables après let dans ES6, une chose à noter est que lors de la déclaration d'une variable, vous devez lui attribuer une valeur, sinon une erreur sera signalée.

5. Problème Window.event

Description du problème : window.event ne peut être exécuté que sous IE, mais pas sous Firefox En effet, l'événement de Firefox ne peut être exécuté que lorsque l'événement se produit. Pour une utilisation sur site.

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 :

<input type="button" onclick="doSomething(event)"/> 
<script language="javascript"> 
function doSomething(evt) { 
    var myEvent = evt?evt:(window.event?window.event:null) 
    ...} 123456
Copier après la connexion
6. Problèmes avec event.x et event.y

7 Récupérer la position de la souris sur la page

Sous IE, l'objet événement. a des attributs x, y. Mais il n'y a pas d'attributs pageX, pageY ;
Sous Firefox, l'objet événement a des attributs pageX, pageY, mais pas d'attributs x, y.

Solution :

Utilisez mX (mX = event. x ? event.x : event.pageX;) pour remplacer event.x sous IE ou event.pageX sous Firefox.

Concernant le problème de frame

<🎜. >Prenons le cadre suivant comme exemple :

1. Accédez à l'objet frame

IE : utilisez window.frameId ou window.frameName pour accéder à l'objet frame
Firefox : utilisez window.frameName pour accéder au frame ; object;
Solution : Unification Utilisez window.document.getElementById("frameId") pour accéder à cet objet cadre ;
2. Changer le contenu du cadre
Vous pouvez utiliser window.document.getElementById("frameId"). src = " webjx.com.html" ou window.frameName.location = "webjx.com.html" pour changer le contenu du cadre
Si vous devez transmettre les paramètres du cadre à la fenêtre parent ; vous pouvez utiliser
parent dans le mot-clé du cadre
pour accéder à la fenêtre parent. 8. 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, alors que l'objet body d'IE doit l'être avant que la balise body ne soit lue. n'existe pas tant que le navigateur ne l'a pas complètement lu.

[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 été chargé. encore.

9. Méthode de délégation d'événement

Event对象提供了一个属性叫target,可以返回事件的目标节点,我们成为事件源,也就是说,target就可以表示为当前的事件操作的dom,但是不是真正操作dom,当然,这个是有兼容性的,标准浏览器用ev.target,IE浏览器用event.srcElement,此时只是获取了当前节点的位置,并不知道是什么节点名称,这里我们用nodeName来获取具体是什么标签名,这个返回的是一个大写的,我们需要转成小写再做比较(习惯问题):

window.onload = function(){
     var oUl = document.getElementById("ul1");
     oUl.onclick = function(ev){
        var ev = ev || window.event;
            var target = ev.target || ev.srcElement;
           if(target.nodeName.toLowerCase() == &#39;li&#39;){
                alert(123);
         alert(target.innerHTML);
        }
     }
}1234567891011
Copier après la connexion

十、访问的父元素的区别

问题说明:在IE下,使用 obj.parentElement 或 obj.parentNode 访问obj的父结点;在firefox下,使用 obj.parentNode 访问obj的父结点。
解决方法:因为firefox与IE都支持DOM,因此统一使用obj.parentNode 来访问obj的父结点。

十一、innerText的问题.

问题说明:innerText在IE中能正常工作,但是innerText在FireFox中却不行。
解决方法:在非IE浏览器中使用textContent代替innerText。

if(navigator.appName.indexOf("Explorer") >-1){ 
    document.getElementById(&#39;element&#39;).innerText = "my text"; 
} 
else{ 
    document.getElementById(&#39;element&#39;).textContent = ";my text"; 
}123456
Copier après la connexion

十二、用setAttribute设置事件

var obj = document.getElementById(&#39;objId&#39;); 
obj.setAttribute(&#39;onclick&#39;,&#39;funcitonname();&#39;);12
Copier après la connexion

FIREFOX支持,IE不支持
解决办法:
IE中必须用点记法来引用所需的事件处理程序,并且要用赋予匿名函数

var obj = document.getElementById(&#39;objId&#39;); 
obj.onclick=function(){fucntionname();};12
Copier après la connexion

十三、设置类名

setAttribute(‘class’,’styleClass’)
FIREFOX支持,IE不支持(指定属性名为class,IE不会设置元素的class属性,相反只使用setAttribute时IE自动识CLASSNAME属性)
解决办法如下:

setAttribute(&#39;class&#39;,&#39;styleClass&#39;) 
setAttribute(&#39;className&#39;,&#39;styleClass&#39;) 
//或者直接
 object.className=&#39;styleClass&#39;;123456
Copier après la connexion

十四、绑定事件

在IE下我们通常使用attachEvent方法

var btn1Obj = document.getElementById("btn1"); //object.attachEvent(event,function); btn1Obj.attachEvent("onclick",method1); btn1Obj.attachEvent("onclick",method2); btn1Obj.attachEvent("onclick",method3); 12345
Copier après la connexion

可惜这个微软的私人方法,火狐和其他浏览器都不支持,幸运的是他们都支持W3C标准的addEventListener方法

var btn1Obj = document.getElementById("btn1"); 
//element.addEventListener(type,listener,useCapture); btn1Obj.addEventListener("click",method1,false); 
btn1Obj.addEventListener("click",method2,false); 
btn1Obj.addEventListener("click",method3,false); 12345
Copier après la connexion

顺变说一下这两个的使用方式:

addEventListener的使用方式

target.addEventListener(type,listener,useCapture);
Copier après la connexion

target: 文档节点、document、window 或 XMLHttpRequest。
type: 字符串,不含“on”如“click”、“mouseover”、“keydown”等。
listener :实现了 EventListener 接口或者是 JavaScript 中的函数。
useCapture :是否使用捕捉,一般用 false 。
例如:

document.getElementById("testText").addEventListener("keydown", function (event) { alert(event.keyCode); }, false); 1
Copier après la connexion

2.对于attachEvent

target.attachEvent(type, listener);
Copier après la connexion

target: 文档节点、document、window 或 XMLHttpRequest。
type: 字符串,事件名称,含“on”,比如“onclick”、“onmouseover”、“onkeydown”等。
listener :实现了 EventListener 接口或者是 JavaScript 中的函数。

例如:

document.getElementById("txt").attachEvent("onclick",function(event){alert(event.keyCode);}); 1
Copier après la connexion

但是他们都给出了事件的移除方法

removeEventListener(event,function,capture/bubble);
Copier après la connexion

十五、ajax请求

对于ajax请求只要出现兼容性的方面就是创建对象时候的区别我们要考虑IE6的情况,下面给出代码

   //设置IE6的情况,注意,在判断XMLHttpRequest是否存在时将其
    //设置为window.XMLHttpRequest,这样将其设置为属性,在检测时就不是未定义
    //而是undefine
    //1.创建Ajax对象
    if(window.XMLHttpRequest){        var oAjax=new XMLHttpRequest();
    }    else{        var oAjax=new ActiveXObject("Microsoft.XMLHTTP");
    }
Copier après la connexion

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

前端页面测试的方法

javascript中call与apply的应用

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

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)

Comparaison et analyse des différences des versions Bluetooth 5.3 et 5.2 Comparaison et analyse des différences des versions Bluetooth 5.3 et 5.2 Dec 28, 2023 pm 06:08 PM

De nos jours, de nombreux téléphones mobiles prétendent prendre en charge la version Bluetooth 5.3, alors quelle est la différence entre Bluetooth 5.3 et 5.2. En fait, il s'agit essentiellement de versions mises à jour ultérieures de Bluetooth 5, et il n'y a pas beaucoup de différence dans la plupart des performances et des fonctions. La différence entre Bluetooth 5.3 et 5.2 : 1. Les débits de données 1 et 5.3 peuvent prendre en charge des débits de données plus élevés jusqu'à 2 Mbps. 2. Alors que le 5.2 ne peut atteindre qu'un maximum de 1 Mbps, cela signifie que le 5.3 peut transmettre des données plus rapidement et de manière plus stable. 2. Amélioration du contrôle de cryptage 2. Bluetooth 5.3 améliore les options de contrôle de la longueur des clés de cryptage, améliore la sécurité et peut mieux se connecter au contrôle d'accès et à d'autres appareils. 3. En même temps, le contrôle administrateur étant plus simple, la connexion peut être plus pratique et plus rapide, ce qui n'est pas possible dans la version 5.2.

Solution au i7-7700 impossible de passer à Windows 11 Solution au i7-7700 impossible de passer à Windows 11 Dec 26, 2023 pm 06:52 PM

Les performances du i77700 sont tout à fait suffisantes pour exécuter Win11, mais les utilisateurs constatent que leur i77700 ne peut pas être mis à niveau vers Win11. Cela est principalement dû aux restrictions imposées par Microsoft, ils peuvent donc l'installer tant qu'ils ignorent cette restriction. Le i77700 ne peut pas être mis à niveau vers win11 : 1. Parce que Microsoft limite la version du processeur. 2. Seules les versions Intel de huitième génération et supérieures peuvent directement passer à Win11. 3. En tant que 7ème génération, i77700 ne peut pas répondre aux besoins de mise à niveau de Win11. 4. Cependant, le i77700 est tout à fait capable d'utiliser Win11 en douceur en termes de performances. 5. Vous pouvez donc utiliser le système d'installation directe win11 de ce site. 6. Une fois le téléchargement terminé, cliquez avec le bouton droit sur le fichier et « chargez-le ». 7. Double-cliquez pour exécuter l'opération "Un clic

Dans quelle mesure le langage Go est-il compatible sur les systèmes Linux ? Dans quelle mesure le langage Go est-il compatible sur les systèmes Linux ? Mar 22, 2024 am 10:36 AM

Le langage Go a une très bonne compatibilité sur les systèmes Linux. Il peut fonctionner de manière transparente sur diverses distributions Linux et prend en charge des processeurs de différentes architectures. Cet article présentera la compatibilité du langage Go sur les systèmes Linux et démontrera sa puissante applicabilité à travers des exemples de code spécifiques. 1. Installez l'environnement de langage Go L'installation de l'environnement de langage Go sur un système Linux est très simple. Il vous suffit de télécharger le package binaire Go correspondant et de définir les variables d'environnement appropriées. Voici les étapes pour installer le langage Go sur le système Ubuntu :

Puis-je utiliser des écouteurs Bluetooth en mode avion ? Puis-je utiliser des écouteurs Bluetooth en mode avion ? Feb 19, 2024 pm 10:56 PM

Avec le développement continu de la technologie moderne, les casques Bluetooth sans fil sont devenus un élément indispensable de la vie quotidienne des gens. L'émergence des écouteurs sans fil libère nos mains, nous permettant de profiter plus librement de la musique, des appels et d'autres activités de divertissement. Or, lorsque nous prenons l’avion, on nous demande souvent de mettre notre téléphone en mode avion. La question est donc : puis-je utiliser des écouteurs Bluetooth en mode avion ? Dans cet article, nous explorerons cette question. Tout d’abord, comprenons ce que fait et signifie le mode avion. Le mode avion est un mode spécial pour les téléphones mobiles

Explication détaillée des problèmes de compatibilité Win11 avec le logiciel Win10 Explication détaillée des problèmes de compatibilité Win11 avec le logiciel Win10 Jan 05, 2024 am 11:18 AM

Le logiciel du système win10 a été parfaitement optimisé, mais pour les derniers utilisateurs de win11, tout le monde doit être curieux de savoir si ce système peut être pris en charge, voici donc une introduction détaillée au logiciel qui ne prend pas en charge win10 dans win11. Venez le trouver. sortir ensemble. Win11 prend-il en charge le logiciel Win10 : 1. Le logiciel système Win10 et même les applications système Win7 sont bien compatibles. 2. Selon les commentaires des experts qui utilisent le système Win11, il n'y a actuellement aucun problème d'incompatibilité des applications. 3. Vous pouvez donc effectuer une mise à niveau en toute confiance, mais il est conseillé aux utilisateurs ordinaires d'attendre la sortie de la version officielle de Win11 avant de procéder à la mise à niveau. 4. Win11 a non seulement une bonne compatibilité, mais aussi Windo

Compatibilité WIN10 perdue, étapes pour la récupérer Compatibilité WIN10 perdue, étapes pour la récupérer Mar 27, 2024 am 11:36 AM

1. Cliquez avec le bouton droit sur le programme et constatez que l'onglet [Compatibilité] est introuvable dans la fenêtre des propriétés qui s'ouvre. 2. Sur le bureau Win10, cliquez avec le bouton droit sur le bouton Démarrer dans le coin inférieur gauche du bureau et sélectionnez l'élément de menu [Exécuter] dans le menu contextuel. 3. La fenêtre d'exécution Win10 s'ouvrira, entrez gpedit.msc dans la fenêtre, puis cliquez sur le bouton OK. 4. La fenêtre de l'éditeur de stratégie de groupe local s'ouvrira. Dans la fenêtre, cliquez sur l'élément de menu [Configuration ordinateur/Modèles d'administration/Composants Windows]. 5. Dans le menu des composants Windows ouvert, recherchez l'élément de menu [Compatibilité des applications], puis recherchez l'élément de paramètre [Supprimer la page de propriétés de compatibilité du programme] dans la fenêtre de droite. 6. Cliquez avec le bouton droit sur l'élément de paramètre et dans le menu contextuel

Comment activer l'accès administratif à partir de l'interface utilisateur Web du cockpit Comment activer l'accès administratif à partir de l'interface utilisateur Web du cockpit Mar 20, 2024 pm 06:56 PM

Cockpit est une interface graphique Web pour les serveurs Linux. Il est principalement destiné à faciliter la gestion des serveurs Linux pour les utilisateurs nouveaux/experts. Dans cet article, nous aborderons les modes d'accès à Cockpit et comment basculer l'accès administratif à Cockpit depuis CockpitWebUI. Sujets de contenu : Modes d'entrée du cockpit Trouver le mode d'accès actuel au cockpit Activer l'accès administratif au cockpit à partir de CockpitWebUI Désactiver l'accès administratif au cockpit à partir de CockpitWebUI Conclusion Modes d'entrée au cockpit Le cockpit dispose de deux modes d'accès : Accès restreint : il s'agit de la valeur par défaut pour le mode d'accès au cockpit. Dans ce mode d'accès vous ne pouvez pas accéder à l'internaute depuis le cockpit

Présentation de la méthode de téléchargement de pilote pour Win10 pour garantir la compatibilité Présentation de la méthode de téléchargement de pilote pour Win10 pour garantir la compatibilité Jan 01, 2024 pm 06:59 PM

Le pilote d'un périphérique matériel est l'un des programmes les plus importants pour que nous puissions utiliser ce périphérique normalement, mais nous pouvons parfois constater que le pilote que nous téléchargeons et installons est incompatible. En fait, le système peut trouver automatiquement un pilote compatible à télécharger et à télécharger. installons-le. Examinons-le ensemble. Comment rendre le pilote Win10 compatible ? 1. Recherchez d'abord cet ordinateur sur le bureau, cliquez avec le bouton droit et sélectionnez pour ouvrir « Propriétés » 2. Recherchez et ouvrez ensuite le « Gestionnaire de périphériques » sur la gauche 3. Recherchez le périphérique que vous souhaitez télécharger et installez dans le gestionnaire de périphériques, faites un clic droit et sélectionnez "Mettre à jour le pilote" 4. Sélectionnez ensuite "Rechercher automatiquement le logiciel pilote mis à jour" 5. Enfin, attendez un moment et la fenêtre suivante apparaîtra, ce qui signifie que l'installation du pilote est terminée .

See all articles