Heim  >  Artikel  >  Web-Frontend  >  CSS-Tutorial, CSS- und Document_Experience-Austausch

CSS-Tutorial, CSS- und Document_Experience-Austausch

WBOY
WBOYOriginal
2016-05-16 12:05:001235Durchsuche
Cascading Style Sheets: The Definitive Guide, 2nd Edition is a thorough review of all aspects of CSS2.1 and a comprehensive guide to CSS implementation. The book includes new content on positioning, lists and generated content, table layout, user interface, paged media, and more. It explores in detail each individual CSS property and how it interacts with other properties, and shows how to avoid common mistakes in interpretation.
 
W3cCss主页:
http://www.w3.org/Style/CSS/
1 css和document
1.1 elements
html中的元素很容易辨识,如p,table,span,a,div。
xml中元素由dtd定义,或者xml schema定义。每个元素部分代表了其表现方式。
Css中可以看作每个元素产生一个box,该box包含了元素的内容。
1.1.1元素类型:replaced和nonreplaced elements,block-level和inline-level elements
replaced elements:元素的内容可以被不是直接由文档表示的内容替换。典型的是xhtml中的img,它可以被指向文档外部的图片文件代替。
    Input元素也可以根据其type的不同,而被radio button,checkbox,text input box代替。
    Replaced elements也在显示时产生一个box。
Nonreplaced elements:html和xhtml的大多数元素是nonreplaced。就是说,这些元素的内容由用户代理(user agent,通常是指浏览器)在元素产生的box中来表述present。(box是不是指元素对应在页面上的一个region?)。
    比如hi there是nonreplaced,文本hi here将由user agent
来显示。
 
Block-level element块元素:产生一个元素box,该box填充其父元素的内容区域,并且其两边没有其他元素。就是说在默认的情况下每个block-level都是单独一行的。比如p,div。
list items是一种特殊的块元素。为了跟其他块元素具有统一的行为,为无序的lists产生一个符号,如bullet;为有序的lists产生一个数字。将符号或数字加到元素box上。除了符号的表现方式外,其他特性跟其余的块元素一样。
Inline-level element内联元素:产生一个元素box,其中是一行文本,并且不是单独一行的。
典型的例子是xhtml中的a元素,另外如strong,em。因为内联元素不会打断其前后的
显示,所以内联元素出现在其他元素中的话不会打断其他元素的显示。
 
注意:xhtml和html中块元素不能从内联元素继承,但是css中没有类似规定。没有限制元素嵌套方式。

Blockelement ist im Allgemeinen ein Containerelement für andere Elemente, das im Allgemeinen in einer neuen Zeile beginnt. Es kann Inline-Elemente und andere Blockelemente aufnehmen, Ein häufiges Blockelement ist das Absatz-Tag „P. „form“ Dieses Blockelement ist etwas Besonderes. Es kann nur zur Aufnahme anderer Blockelemente verwendet werden.

Ohne den CSS-Effekt werden die Blockelemente zeilenweise nacheinander angeordnet. Mit CSS können wir den Standardlayoutmodus von HTML ändern und die Blockelemente an der gewünschten Stelle platzieren . Anstatt jedes Mal dummerweise eine neue Zeile zu beginnen. Es sollte darauf hingewiesen werden, dass das Tag auch eine Art Blockelement ist. Tabellenbasiertes Layout und CSS-basiertes Layout sind für allgemeine Benutzer konzipiert (außer visuell). Beeinträchtigt, aus der Sicht blinder Menschen usw.) gibt es keinen weiteren Unterschied zwischen diesen beiden Layouts außer dem Unterschied in der Seitenladegeschwindigkeit. Wenn jedoch ein normaler Benutzer versehentlich auf die Schaltfläche Quellcode der Seite anzeigen klickt, ist der Unterschied zwischen beiden sehr groß. Der auf guten Rekonstruktionskonzepten basierende CSS-Layout-Seitenquellcode kann es zumindest normalen Benutzern ohne Web Entwicklungserfahrung ermöglichen, den Inhalt schnell zu lesen. Aus dieser Perspektive sollte CSS-Layoutcode ein besseres ästhetisches Erlebnis haben.

Sie können sich das Blockcontainerelement div als Boxen , vorstellen oder wenn Sie Schrotttext abgespielt haben, If so wird es leichter zu verstehen sein. Wir schneiden zunächst die benötigten Artikel aus verschiedenen Zeitungen und Zeitschriften aus . Der ausgeschnittene Inhalt jedes Blocks ist ein Block. Anschließend haben wir diese Papierstücke entsprechend unserer Layout-Intention auf ein neues Blatt leeres Papier geklebt. Dadurch entsteht Ihr ganz eigener Digest . Als Erweiterung der Technologie folgt das Weblayout-Design demselben Muster. .

 Inline-Elemente(Inline-Element)basieren im Allgemeinen auf der semantischen Ebene (Semantik) Die Grundelement von . Inline-Elemente können nur Text oder andere Inline-Elemente aufnehmen: „a“ .

Blockelement und Inline-Element sind beide HTML Konzepte in der Spezifikation. Der grundlegende Unterschied zwischen Blockelementen und Inline-Elementen besteht darin, dass Blockelemente im Allgemeinen in einer neuen Zeile beginnen. Und wenn das CSS--Steuerelement hinzugefügt wird, wird der Attribut--Unterschied zwischen Blockelementen und Inline-Elementen kein Unterschied mehr. Beispielsweise können wir dem Inline-Element cite ein Attribut wie display:block hinzufügen, sodass es auch das Attribut hat, jedes Mal in einer neuen Zeile zu beginnen.

 Das Grundkonzept des variablen Elements besteht darin, dass anhand des Kontexts bestimmt werden muss, ob das Element ein Blockelement oder ein Inline-Element ist. Variable Elemente gehören immer noch zu den beiden oben genannten Elementkategorien. Sobald der Kontext ihre Kategorie bestimmt, müssen sie den Regeln von Blockelementen oder Inline-Elementen folgen. Eine grobe Elementklassifizierung finden Sie im Volltext.

ps:Über den chinesischen Namen des Inline-Elements gibt es viele Inline-Elemente und eingebettete Elemente, Inline Elemente und Inline-Elemente. Grundsätzlich gibt es keine einheitliche Übersetzung, nennen Sie sie einfach wie Sie wollen. Wenn es um Inline-Elemente geht, denken wir außerdem an Das Attribut display:inline; Problem mit doppeltem schwebendem Rand.

块元素(block element)
* address - 地址
* blockquote - 块引用
* center - 举中对齐块
* dir - 目录列表
* div - 常用块级容易,也是css layout的主要标签
* dl - 定义列表
* fieldset - form控制组
* form - 交互表单
* h1 - 大标题
* h2 - 副标题
* h3 - 3级标题
* h4 - 4级标题
* h5 - 5级标题
* h6 - 6级标题
* hr - 水平分隔线
* isindex - input prompt
* menu -
菜单列表
* noframes - frames可选内容,(对于不支持frame的浏览器显示此区块内容
* noscript - )可选脚本内容(对于不支持script的浏览器显示此内容)
* ol - 排序表单
* p - 段落
* pre - 格式化文本
* table - 表格
* ul - 非排序列表

内联元素(inline element)
* a - 锚点
* abbr - 缩写
* acronym - 首字
* b - 粗体(不推荐)
* bdo - bidi override
* big -
大字体
* br - 换行
* cite - 引用
* code - 计算机代码(在引用源码的时候需要)
* dfn - 定义字段
* em - 强调
* font - 字体设定(不推荐)
* i - 斜体
* img - 图片
* input - 输入框
* kbd - 定义键盘文本
* label - 表格标签
* q - 短引用
* s - 中划线(不推荐)
* samp - 定义范例计算机代码
* select - 项目选择
* small - 小字体文本
* span - 常用内联容器,定义文本内区块
* strike - 中划线
* strong - 粗体强调
* sub - 下标
* sup - 上标
* textarea - 多行文本输入框
* tt - 电传文本

* u - 下划线
* var - 定义变量

可变元素
可变元素为根据上下文语境决定该元素为块元素或者内联元素。
* applet - java applet
* button -
按钮
* del - 删除文本
* iframe - inline frame
* ins -
插入的文本
* map - 图片区块(map)
* object - object对象
* script - 客户端脚本

Ein Beispiel:
<span style="FONT-SIZE: 10.5pt"><body></span>
<span style="FONT-SIZE: 10.5pt"><p>This is a paragraph with <em>an inline element</em> within it.</p></span>
<span style="FONT-SIZE: 10.5pt"></body></span>
Im obigen Beispiel gibt es zwei Blockelemente, p und body, und ein Inline-Element em.
In xhtml kann em von p erben, aber nicht umgekehrt. In xhtml können Inline-Elemente von Blockelementen erben, aber nicht umgekehrt.
In CSS gibt es keine solche Bestimmung und CSS kann die Struktur des obigen Beispiels ändern.
p {display: inline;}
em {display: block;}
Blockbox in Inline-Box einfügen. Wirkung:
Das Ändern der Anzeigerolle eines Elements ist in xhtml nützlich. XML-Dokumente haben keine geerbten Anzeigerollen, daher ist es wichtig, sie über CSS zu definieren.
<span style="FONT-SIZE: 10.5pt"><book></span>
<span style="FONT-SIZE: 10.5pt"> <maintitle>Cascading Style Sheets: The Definitive Guide</maintitle></span>
<span style="FONT-SIZE: 10.5pt"> <subtitle>Second Edition</subtitle></span>
<span style="FONT-SIZE: 10.5pt"> <author>Eric A. Meyer</author></span>
<span style="FONT-SIZE: 10.5pt"> <publisher>O'Reilly and Associates</publisher></span>
<span style="FONT-SIZE: 10.5pt"> <pubdate>2004</pubdate></span>
<span style="FONT-SIZE: 10.5pt"> <isbn>blahblahblah</isbn></span>
<span style="FONT-SIZE: 10.5pt"></book></span>
<span style="FONT-SIZE: 10.5pt"><book></span>
<span style="FONT-SIZE: 10.5pt"> <maintitle>CSS2 Pocket Reference</maintitle></span>
<span style="FONT-SIZE: 10.5pt"> <author>Eric A. Meyer</author></span>
<span style="FONT-SIZE: 10.5pt"> <publisher>O'Reilly and Associates</publisher></span>
<span style="FONT-SIZE: 10.5pt"> <pubdate>2004</pubdate></span>
<span style="FONT-SIZE: 10.5pt"> <isbn>blahblahblah</isbn></span>
<span style="FONT-SIZE: 10.5pt"></book></span>
<span style="FONT-SIZE: 10.5pt">默认的显示:</span>
<span>
 <img alt="" src="http://www.webjx.com/files/allimg/080827/0125162.png">
</span>
<span style="FONT-SIZE: 10.5pt">用</span><span style="FONT-SIZE: 10.5pt">css</span><span style="FONT-SIZE: 10.5pt">来定义显示层次:</span>
<span style="FONT-SIZE: 10.5pt">book, maintitle, subtitle, author, isbn {display: block;}</span>
<span style="FONT-SIZE: 10.5pt">publisher, pubdate {display: inline;}</span>
<span style="FONT-SIZE: 10.5pt">现在显示:</span>
<span>
 <img alt="" src="http://www.webjx.com/files/allimg/080827/0125163.png">
</span>
kann sich auf Anzeigerollen auswirken Die Eigenschaften von Anzeigerollen sind CSS ist in vielen Situationen äußerst nützlich.
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn