Accueil > > > CRÉER UNE RÈGLE CSS POUR QU'ELLE S'APPLIQUE À UNE ÉLÉMENT DONNÉ (UNE BALISE / NOEUD (X)HTML)
CRÉER UNE RÈGLE CSS POUR QU'ELLE S'APPLIQUE À UNE ÉLÉMENT DONNÉ (UNE BALISE / NOEUD (X)HTML)
Information sur la source
Description
Voici un simple petit code JavaScript sans prétention mais qui peut se révéler utile dans certaines occasions Comme vous pouvez le constater le but ici est de simuler une publicité et de trouver une règle CSS qui permettra de la supprimer avec le moins d'effet collatéraux possibles (et si possible aucun !) Je ne vous cache pas que le choix de la publicité est loin d'être anodin vu que c'est précisément ce code (ou sa retranscription en C++) qui sera utilisé pour les CSS Filters du filtre anti-pub d'IE7Pro, si ils voient le jour. Le code prévoit plusieurs mode de fonctionnement : - IE6 (et IE7-BackCompat) ou IE7 - Normal ou Safe La distinction entre IE6 et IE7 se fait dans les sélecteurs CSS, beaucoup plus nombreuse sous IE7 qui permettent de limiter fortement le risque de dégâts collatéraux Le mode Safe ne considère plus comme suffisant une simple classe CSS ou un nom (attribut name) pour terminer la règle, alors que le monde Normal s'en contente. Voici déjà un aperçu de ce que le code peut générer : - IE 6 (normal) : DIV.adctner TABLE - IE 6 (safe) : DIV#content DIV.adctner TABLE - IE 7 (normal) : TABLE[name="table"] - IE 7 (safe) : DIV#content > DIV.adctner > TABLE[name="table"]
Source
- <!Doctype XHTML 1.1 dtd!>
- <html>
- <head>
- <title>Catch by CSS</title>
- <style>
- pre { cursor: hand; display:inline; }
- b { float: left; width: 100px; }
- div.content { border: 1px; padding: 5px; }
- div.adctner { float:left; }
- a img { border-style: none }
- </style>
- <script type="text/javascript">
- function catchByCss(el, ie7, times, safe) {
- var isCatched = {value: false};
- safe = !(safe);
-
- ie7=(ie7 && document.compatMode!="BackCompat");
-
- function isNullOrEmpty(o) {
- return (
- typeof (o) == "undefined" ||
- o==null ||
- o=="" ||
- o==0
- );
- }
- function catchBy(el, key) {
- if (isNullOrEmpty(el[key])) {
- return "";
- }
- switch (key) {
- case "tagName":
- if (el.tagName=="BODY" || el.tagName=="HTML" || isNullOrEmpty(el.parentNode) || el.parentNode==document) {
- isCatched.value=true;
- }
- return el.tagName;
- case "id":
- if(el.id.indexOf(" ")==(-1)) {
- isCatched.value=true;
- return "#"+el.id;
- }
- if (ie7) {
- isCatched.value=true;
- return '[id="' + el.id + '"]';
- }
- return "";
- case "className":
- if (isCatched.value && String(el.id).indexOf(" ")!=(-1)) { return ""; }
- if(el.className.indexOf(" ")==(-1)) {
- isCatched.value=(safe && true);
- return "."+el.className;
- }
- return "."+(el.className).replace(/(\s)+/g, ".")
- case "name":
- if (ie7) {
- isCatched.value=(safe && true);
- return '[name="' + el.name + '"]';
- }
- return "";
- default: return "";
- }
- }
-
- var css = "";
- while (times > -1 || isNullOrEmpty(el)) {
- while (!isCatched.value) {
- try {
- var tmp = "";
- tmp += catchBy(el, "tagName");
- tmp += catchBy(el, "id");
- tmp += catchBy(el, "className");
- tmp += catchBy(el, "name");
- css = tmp + (css==""?"":(ie7?" > ":" ")) + css;
- el=el.parentNode;
- } catch (ex) {
- return css;
- }
- }
- times--;
- isCatched.value=false;
- }
- return css;
- }
-
- function addStyle(css) {
- alert(css);
- var s = document.createStyleSheet();
- s.cssText=css;
- }
-
- window.onload = function tryCatch() {
- var el = document.getElementById("catch")
- el.id="";
- document.getElementById( "result_IE7" ).innerText = catchByCss( el, true , 0 )
- document.getElementById( "result_IE6" ).innerText = catchByCss( el, false , 0 )
- document.getElementById( "result_IE7_safe" ).innerText = catchByCss( el, true , 0, true )
- document.getElementById( "result_IE6_safe" ).innerText = catchByCss( el, false , 0, true )
- }
- </script>
- </head>
- <body>
- <b>IE 6 (normal)</b> : <pre id="result_IE6" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
- <b>IE 6 (safe)</b> : <pre id="result_IE6_safe" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
- <b>IE 7 (normal)</b> : <pre id="result_IE7" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
- <b>IE 7 (safe)</b> : <pre id="result_IE7_safe" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
- <div id="content">
- <div class="adctner">
- <table name="table" id="catch">
- <tr>
- <td>
- <a href="#">
- <img width="200" height="200px" src="http://ads.mulhouse.free.fr/Images/logo%20ADS.JPG" />
- </a>
- </td>
- </tr>
- <tr><td style="font-size: 10px; text-align: right;">Ads by google</td></tr>
- </table>
- </div>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
- ContenuContenuContenuContenuContenuContenuContenuContenuContenu
- </div>
- </body>
- </html>
<!Doctype XHTML 1.1 dtd!>
<html>
<head>
<title>Catch by CSS</title>
<style>
pre { cursor: hand; display:inline; }
b { float: left; width: 100px; }
div.content { border: 1px; padding: 5px; }
div.adctner { float:left; }
a img { border-style: none }
</style>
<script type="text/javascript">
function catchByCss(el, ie7, times, safe) {
var isCatched = {value: false};
safe = !(safe);
ie7=(ie7 && document.compatMode!="BackCompat");
function isNullOrEmpty(o) {
return (
typeof (o) == "undefined" ||
o==null ||
o=="" ||
o==0
);
}
function catchBy(el, key) {
if (isNullOrEmpty(el[key])) {
return "";
}
switch (key) {
case "tagName":
if (el.tagName=="BODY" || el.tagName=="HTML" || isNullOrEmpty(el.parentNode) || el.parentNode==document) {
isCatched.value=true;
}
return el.tagName;
case "id":
if(el.id.indexOf(" ")==(-1)) {
isCatched.value=true;
return "#"+el.id;
}
if (ie7) {
isCatched.value=true;
return '[id="' + el.id + '"]';
}
return "";
case "className":
if (isCatched.value && String(el.id).indexOf(" ")!=(-1)) { return ""; }
if(el.className.indexOf(" ")==(-1)) {
isCatched.value=(safe && true);
return "."+el.className;
}
return "."+(el.className).replace(/(\s)+/g, ".")
case "name":
if (ie7) {
isCatched.value=(safe && true);
return '[name="' + el.name + '"]';
}
return "";
default: return "";
}
}
var css = "";
while (times > -1 || isNullOrEmpty(el)) {
while (!isCatched.value) {
try {
var tmp = "";
tmp += catchBy(el, "tagName");
tmp += catchBy(el, "id");
tmp += catchBy(el, "className");
tmp += catchBy(el, "name");
css = tmp + (css==""?"":(ie7?" > ":" ")) + css;
el=el.parentNode;
} catch (ex) {
return css;
}
}
times--;
isCatched.value=false;
}
return css;
}
function addStyle(css) {
alert(css);
var s = document.createStyleSheet();
s.cssText=css;
}
window.onload = function tryCatch() {
var el = document.getElementById("catch")
el.id="";
document.getElementById( "result_IE7" ).innerText = catchByCss( el, true , 0 )
document.getElementById( "result_IE6" ).innerText = catchByCss( el, false , 0 )
document.getElementById( "result_IE7_safe" ).innerText = catchByCss( el, true , 0, true )
document.getElementById( "result_IE6_safe" ).innerText = catchByCss( el, false , 0, true )
}
</script>
</head>
<body>
<b>IE 6 (normal)</b> : <pre id="result_IE6" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
<b>IE 6 (safe)</b> : <pre id="result_IE6_safe" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
<b>IE 7 (normal)</b> : <pre id="result_IE7" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
<b>IE 7 (safe)</b> : <pre id="result_IE7_safe" onclick="addStyle(this.innerText + ' { display: none }')"></pre><br/>
<div id="content">
<div class="adctner">
<table name="table" id="catch">
<tr>
<td>
<a href="#">
<img width="200" height="200px" src="http://ads.mulhouse.free.fr/Images/logo%20ADS.JPG" />
</a>
</td>
</tr>
<tr><td style="font-size: 10px; text-align: right;">Ads by google</td></tr>
</table>
</div>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu<br/>
ContenuContenuContenuContenuContenuContenuContenuContenuContenu
</div>
</body>
</html>
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Ajouter une image dynamiquement sour Firfooxe [ par Fildomen ]
Salut !! encore un prob de compatibilité !!!j'ajoute des images a un iframe !! des smileys !! ca marche impec sous IE !! mais avec firefox !! il ajout
creer des onglet sans utiliser css [ par amaila ]
boujour à tous.je veux faire ajouter des onglets en javascript sans uitliser CSS.est il possible?si oui vous pouvez m'aider de trouver des exemples si
largeur de chaque element d'un menu horizontal en css [ par stopworries ]
Bonjour tlm!Voila g un menu horizontal en css et js qui fonctionne tres bien, le seul probleme, c que dans ma barre de menu, g par exple les titres "f
pb ie : ajouter un <option> à un <select> à partir d'une popup [ par yosh ]
Bon c assez compliqué mais je vai essayer d'être le plu clair possible J'ai une page dans laquel j'utilise la technologie AJAX couplé
Creer une page CSS à partir d'une page html [ par karimfellah ]
slt tous le monde, j'aimerai bien vous posez une question:j'ai besoin d'un code source qui permet de creer une page css à partir d'une page html je m'
ecrire et ajouter un element <link>www.mysyshop.com</link> [ par claudiusse ]
Bonjour a tous j ai un serveur pour mon site j ai ecrit une page html je voudrai que mon utilisateur puisse en cliquant sur un bouton Ajouter un eleme
Cacher une class (css) avec prototype? [ par rebelor91 ]
Bonjour j'ai un DIV à l'interieur de celui ci deux IMG, ces deux images sont superposées et je souhaite pouvoir cacher la deuxième image qui a une cla
Help! Formulaire - Style CSS/PHP & Session [ par LuxeurDelphii ]
Salut, Bon voilà, je m'explique tout rapidement, je ne sais pas non plus si j'ai choisi le bon thème, soit si je suis dans le bon emplacement du suje
Modifier dynamiquement les coordonnées MAP d'une image cliquable [ par eguignier ]
Bonsoir à tous, J'ai une image cliquable accompagnée de zones AREA munies de coordonnées. Cette image est placée dans une div. Un code Javascript per
bouton avec le css et html [ par karl45 ]
bonjour je voulai savoir si il et possible qu'un bouton (que le crée sur photoshop) puisse changer de couleur a passage de la sourie en utilisant le
|
Derniers Blogs
[RIA SERVICES] INCLUDE ET DOMAINDATASOURCE[RIA SERVICES] INCLUDE ET DOMAINDATASOURCE par Audrey
Dans un de mes articles précédents , j'avais parlé des DomainDataSource avec RIA Services dans le cas d'une interface Maître - Détail. Dans le même principe, je vais parler d'une autre manière de mettre en forme ce cas d'interface avec RIA Services. Et po...
Cliquez pour lire la suite de l'article par Audrey ZUNE : VERSION ZUNE SOFTWARE V 4.2 ET LA SOCIALISATIONZUNE : VERSION ZUNE SOFTWARE V 4.2 ET LA SOCIALISATION par ROMELARD Fabrice
Une des nouveautés de la version V 3.0 était l'apparition de l'onglet Social qui ne fonctionnait que si le MarketPlace était activé sur son poste. Cela limitait donc son intérêt, car hors du cadre commercial USA-CANADA, peu de monde trouva...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice PRATIQUE DE SILVERLIGHT PAR ERIC AMBROSIPRATIQUE DE SILVERLIGHT PAR ERIC AMBROSI par MPOWARE
Je viens de finir la lecture du dernier livre d'
Eric Ambrosi
éditions PEARSON
Son livre donne une approche pratique de Silverlight qui sera aussi bien comprise par le développeur que par le designeur.
Tous les aspects du développement RIA sont abor...
Cliquez pour lire la suite de l'article par MPOWARE APPRENDRE à DéVELOPPER POUR LES MOBILES AVEC LA NOUVELLE GéNéRATION .NETAPPRENDRE à DéVELOPPER POUR LES MOBILES AVEC LA NOUVELLE GéNéRATION .NET par odewit
2 déclinaisons de Silverlight et 2 déclinaisons de Mono permettent dorénavant (ou permettront prochainement) de développer des applications .NET mobiles pour les principales plates-formes du marché :
Silverlight pour Symbian, basé sur Silverlight 2...
Cliquez pour lire la suite de l'article par odewit ZUNE : NOUVELLE VERSION DU ZUNE SOFTWARE - V 4.2ZUNE : NOUVELLE VERSION DU ZUNE SOFTWARE - V 4.2 par ROMELARD Fabrice
Avec la dernière génération du lecteur MP3 de Microsoft, le ZUNE HD, Microsoft a publié une nouvelle version du logiciel pour PC. Ainsi, je me suis décidé à installer celle-ci sur mon Tablet PC ACER, comme toujours le logiciel est donc tél...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Forum
RE : CONVERSIONRE : CONVERSION par peter2010
Cliquez pour lire la suite par peter2010
Logiciels
Academy System (10.9.4.0)ACADEMY SYSTEM (10.9.4.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods
|