Maison  >  Article  >  interface Web  >  Si vous voulez pratiquer CSS, vous devez d'abord résoudre une analyse détaillée de l'échange IE_Experience

Si vous voulez pratiquer CSS, vous devez d'abord résoudre une analyse détaillée de l'échange IE_Experience

WBOY
WBOYoriginal
2016-05-16 12:04:461308parcourir

更加坏的事情是,即使你仅仅针对IE设计,不考虑其它浏览器,由于IE模型绝对可以说是一只让人难以捉摸其脾气的怪物,所以你单纯为IE设计也会遇到众多难题,发现很多的效果总是绕来绕去都难以实现。

我们都知道,XHTML+CSS的目标就是实现内容与表现分离,理论上对于任何特定一份内容,我们都可以通过CSS实现任何我们想要的表现形式,或者细致地说是布局形式。虽然现实与这个目标有一定差距,但是CSS已经能够满足大多数常见的布局需求,这有CSS Zen Garden为证。然而如果你用的是IE,因为它难以捉摸,所以如果你想用一种简单优雅的CSS去让IE能够实现“任何你想要的布局形式”,那是不可能的,只有复杂繁缛的CSS才能够在IE上满足你的需求。我曾经提到过一种理论,“一个人对一个研究方向是否感兴趣很可能是完全靠偶然事件决定的,这就好像人第一次打羽毛球,如果你赢了几盘你就会感兴趣,如果你一直都赢不了你就会没兴趣”。IE在需要复杂繁缛的CSS这一点上,就足以令大多数的入门者却步。你总感觉到不得要领,你自然没兴趣学下去。

举一个例子说明这个问题,例如你不知道IE有hasLayout这回事,一个元素是否hasLayout对它的布局方式有重大影响,于是你肯定用最简单的思维去思考CSS,认为不同的CSS规则之间应该是松耦合的。“CSS应该被设计为简单优雅的”,你肯定会这样想,没错,它确实被设计为这样,不过IE不是这样去实现CSS罢了。我们用下面的代码去证明IE在quirks mode与standards mode之间的区别:


 
Hello

 
 
Hello

首先,我们用quirks mode看看结果如何,并且一个初学者看到这样的结果会去如何理解CSS规则。在quirks mode中,我们可以看到背景为红色的

包含了上面1行的文本,以及下面向左浮动的(自然也就包括在浮动块右边的文本),在这里,我们可以建立两种认识:

  1. 容器是完整包含内容的,当内容的总高度比容器大的时候,容器就会自然伸展以确保容纳内容。
  2. 浮动块也属于上述条件所要求通过伸展以确保容纳内容。

以上规则是完全错误的,一个懂得标准CSS以及理解quirks mode的设计师将会如此解释他的理解:

  1. 因为IE在quirks mode中会将height理解为min-height,所以它认为
    的高度不小于height指定的30px即可。而根据CSS标准,当height设置为30px时,高度就一定是30px,超出部分如何处理则由专门的CSS规则决定。
  2. 因为
    被设置了height属性,在IE中这就让它hasLayout了,这就导致它一定要包含所有的内容,包括浮动块。而根据CSS标准,浮动块是无需被完全包含的,它就浮动在那里,除非遇到设置了clear属性的元素,否则后继内容只会侧移避让。

好了,相信这个对比足以说明问题的严重性了,通过IE的效果去理解CSS,最终只会让你的理解与真实的CSS相差甚远。详细的standards mode与quirks mode带来的标准执行差别,可以参考这篇文章:CSS Quirks mode and strict mode

然后肯定有人要问我,如果通过doctype确保使用的是standards mode,那是不是就没问题了呢?standards mode确实会让IE对CSS的解释合理很多,但事情并没有那么简单,这你可以通过实践去慢慢体会。你可以尝试在standards mode中设计CSS,并且尽力保持它们在IE/FF/Opera/Safari这4大主流浏览器中显示一致,随着设计的进行,你会发现这不是那么容易做到的。或许你不乐意花时间去fix其中的一些小问题,宁愿任由其中一些浏览器的用户看到比较丑陋的布局,但至少你已经了解到一个和上面例子类似的道理:不同浏览器即使同样在standards mode,其对CSS的理解仍然有所差异,而差异当中最多只可能有一个是正确的,甚至可能全部都是错误的。这篇CSS contents and browser compatibility就列举了众多浏览器对CSS支持的差异,一份CSS总会因为其中有一些规则在某些浏览器上是不支持的或者是buggy的,而导致你难以保持它们在不同浏览器上显示一致。

接下来可能还有人会问我,既然IE的市场份额最大(特别是在入门级的用户当中),又或者说我的客户指定使用IE作为客户端,仅仅针对IE设计CSS不好吗?为什么要针对FF之类的标准浏览器设计CSS然后再为IE进行fix?因为IE难以捉摸的脾气,让你无法将它的行为理解为一种简单优雅的规则,然后让你陷入CSS规则高度耦合的困境中。请看下面的例子:


 
 
Hello


Hello

现在,你在IE中看到的效果应该是左边出现,然后两个

内的Hello都向右偏移以避让这个浮动块了,其中上面的
仅仅占用移行的高度,因为它没有声明高度,所以就是自然高度,也就是一样,这些都很好理解,所有规则都是解耦的。然后向例子中增加对第一个
的width属性复制,看看结果会如何:

 
 
Hello


Hello

À ce stade, le premier

accueille complètement le , en poussant le deuxième
Comment expliquer cela ? Nous n'avons pas défini son attribut height. Est-ce parce que hasLayout doit accueillir tout le contenu comme mentionné dans l'exemple précédent ? La bonne réponse est que c'est là que IE est difficile à apprivoiser. Un attribut width qui devrait être complètement indépendant, après avoir été défini, provoque d'autres effets que la hauteur, ce qui rend impossible d'essayer de comprendre le comportement d'IE de manière simple et élégante. chemin. Cela prouve que si vous voulez apprendre à concevoir du CSS pour IE, vous devez d'abord apprendre le CSS standard, ainsi que comprendre le comportement étrange d'IE, ce qui est beaucoup plus difficile que simplement apprendre à concevoir pour un navigateur standard. À ce stade, voulez-vous dire : « Si les clients sont prêts à abandonner IE, et même le monde entier est prêt à abandonner IE, ce serait formidable. Oui, c'est la bonne idée, et vous voulez seulement. concevoir pour IE Convenience ne fera que vous rendre fou.

Enfin, si vous avez déjà une certaine base en CSS et avez une compréhension impartiale des règles CSS, mais que vous manquez d'imagination pour combiner les règles CSS et que vous ne parvenez pas à obtenir ce qu'on appelle « réaliser n'importe quel effet de mise en page que vous souhaitez », c'est aussi C'est-à-dire que vos compétences internes ont été développées, il vous manque juste quelques routines superficielles. En ce moment, je vous recommande de lire "Maîtrise CSS/. Maîtrisez CSS》. Après avoir lu ce livre, je pense que vous ressentirez seulement qu'il vous manque la capacité de créer des mises en page, plutôt que d'avoir des mises en page mais de ne pas savoir comment les mettre en œuvre. De plus, si vous faites attention au contenu CSS, vous pouvez envisager de vous abonner à mon blog :

Après le Nouvel An chinois, j'écrirai peut-être quelques articles liés à ASP.NET+CSS, car le développement d'ASP.NET+CSS n'est pas pratique maintenant, même avec l'utilisation de ASP.NET 2.0 Contrôle convivial CSS La même chose est vraie pour les adaptateurs, vous devez donc personnaliser l'adaptateur de contrôle couplé en fonction de votre situation réelle pour résoudre le problème. C'est ce que j'étudierai ensuite.

Déclaration:
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