ホームページ >ウェブフロントエンド >htmlチュートリアル >CSS スタイルのグラフィックとテキストの詳細な説明: css スタイル シートと selector_html/css_WEB-ITnose
CSS: カスケードスタイルシート、カスケードスタイルシート。 CSS の機能は、HTML ページのタグにさまざまなスタイルを追加し、Web ページの表示効果を定義することです。簡単に言うと、CSSはWebページのコンテンツと表示スタイルを分離し、表示機能を向上させます。 次に、なぜ CSS を使用する必要があるのかについて話したいと思います。
HTMLの欠点:複数のデバイスに適応できない
データと表示を分離する
CSS 構文
文法形式: 选择器{ 属性名: 属性值; 属性名: 属性值;}
セレクターはページ上の特定のタイプの要素を表し、セレクターの後には中括弧が必要です。 属性名はコロンで区切る必要があり、属性値はセミコロンで区切る必要があります (最後の属性にはセミコロンは必要ありません)。
属性名とコロンの間にスペースを入れないことが最善です (経験)。
属性に複数の値がある場合、複数の値はスペースで区切られます
p{color: red;}
<style type="text/css"> p{ font-weight: bold; font-style: italic; color: red; }</style> <body> <p>洗白白</p> <p>你懂得</p> <p>我不会就这样轻易的狗带</p> </body>
効果:
CSS コードに関するコメント:
<style type="text/css"> /* 具体的注释 */ p{ font-weight: bold; font-style: italic; color: red; }</style>
注: コメントは /* */ のみあり、// コメントはありません。コメントを有効にするには、c9ccee2e6ea535a969eb3f532ad9fe89 タグ内に記述する必要があります。
次に、CSS の知識について話さなければなりません。
CSS と HTML を組み合わせる方法
CSS と HTML を組み合わせる方法は 3 つあります:
インライン スタイル: style 属性を使用します。スコープはこのタグにのみ適用されます
1. CSS と HTML を組み合わせる方法 1: インライン スタイル
style 属性を使用します。スコープはこのタグにのみ適用されます。
例:
<p style="color:white;background-color:red">我不会就这样轻易的狗带</p>
効果:
2. CSS と HTML を組み合わせる方法 2: 埋め込みスタイルシート
複数のタグを統合して変更するには、c9ccee2e6ea535a969eb3f532ad9fe89 タグを追加します。このページを元にしています。この方法では、単一ページのスタイルを均一に設定できますが、局所的な領域には十分な柔軟性がありません。
<style type="text/css"> p{ font-weight: bold; font-style: italic; color: red; }</style> <body> <p>洗白白</p> <p style="color:blue">你懂得</p> </body>
3. CSSとHTMLを組み合わせる方法3: 外部スタイルシートCSSファイルを導入する
スタイルシートファイルを導入するには2つの方法があります:
(1)<リンク>を使用する;タグ。例: d4ab7bbc793c3cba33744f49074f5796f2b8b73da751f6a0101d6acb3acd2296
(2) import を使用します。これは < で記述する必要があります。 ;style> タグは最初の文でなければなりません。例: @import url(a.css) ;
具体操作如下:
我们先在html页面的同级目录下新建一个a.css文件,那说明这里面的代码全是css代码,此时就没有必要再写c9ccee2e6ea535a969eb3f532ad9fe89标签这几个字了。
a.css的代码如下:
p{ border: 1px solid red; font-size: 40px;}
上方的css代码中,注意像素要带上px这个单位,不然不生效。
然后我们在html文件中通过2cdf5bf648cf2f33323966d7f58a7f3f标签引入这个css文件就行了。效果如下:
这里再讲一个补充的知识:link标签的rel属性
2cdf5bf648cf2f33323966d7f58a7f3f标签的rel属性:
其属性值有以下两种:
看字面意思可能比较难理解,我们来举个例子,一下子就明白了。
举例:
现在定义我们来定义3种样式表:
a.css:定义一个实线的黑色边框
div{ width: 200px; height: 200px; border: 3px solid black;}
ba.css:蓝色的虚线边框
div{ width: 200px; height: 200px; border: 3px dotted blue;}
c.css:来个背景图片
div{ width: 200px; height: 200px; border: 3px solid red; background-image: url("1.jpg");}
然后我们在html文件中引用三个样式表:
<link rel = "stylesheet" type = "text/css" href = "a.css"></link> <link rel = "alternate stylesheet" type = "text/css" href = "b.css" title="第二种样式"></link> <link rel = "alternate stylesheet" type = "text/css" href = "c.css" title="第三种样式"></link>
上面引入的三个样式表中,后面两个样式表作为备选。注意备选的样式表中,title属性不要忘记写,不然显示不出来效果的。现在来看一下效果:(在IE中打开网页)
CSS选择器:就是指定CSS要作用的标签,那个标签的名称就是选择器。意为:选择哪个容器。
CSS的选择器分为两大类:基本选择题和扩展选择器。
基本选择器:
下面来分别讲一讲。
可以匹配针对一类标签。
举例:
p{ font-size:14px;}
上方选择器的意思是说:所有的e388a4556c0f65e1904146cc1a846bee标签里的内容都将显示14号字体。
效果:
优点:灵活。
举例:
.one{ width:800px;}
效果:
针对特定的一个标签来使用,只能使用一次。ID选择器以”#”来定义。
举例:
#mytitle{ border:3px dashed green;}
效果:
上面这三种选择器的区别:
通用选择器,将匹配任何标签。不建议使用,IE有些版本不支持,大网站增加客户端负担。
举例:
*{ margin-left:0px; margin-top:0px;}
效果:
扩展选择器:
下面详细讲一下这三种扩展选择器。
三种基本选择器都可以放进来。
举例:
p,h1,.one,#mytitle{ color:red;}
效果:
对于E F这种格式,表示限定所有属于E元素后代的F元素有这个样式。
看定义可能有点难理解,我们来看例子吧。
举例:
h3 b i{ color:red ; }
上方代码的意思是说:定义了3f7b3decd2dcafb07b84d2d3985d9f40标签中的a4b561c25d9afb9ac8dc4d70affff419标签中的5a8028ccc7a7e27417bff9f05adf5932标签的样式。
注:h3和b和i标签不一定是连续紧挨着的,只要保持一个后代的关联即可。
效果:
或者还有下面这种写法:
上面的这种写法,684271ed9684bde649abda8831d4d355标签和5a8028ccc7a7e27417bff9f05adf5932标签并不是紧挨着的,但他们保持着一种后代关系。
还有下面这种写法:(含类选择器、id选择器都是可以的)
对于3499910bf9dac5ae3c52d5ede7383485标签,其对应几种不同的状态:
CSS允许对于元素的不同状态,定义不同的样式信息。伪类选择器又分为两种:
下面来分别讲一下这两种伪类选择器。
(1)静态伪类:
用于以下两个状态:
注意:上面这两个状态只能使用于超链接。
举例:
<style type="text/css"> /* 伪类选择器:静态伪类 */ /* 让超链接点击之前是红色 */ a:link{ color:red; } /* 让超链接点击之后是绿色 */ a:visited{ color:green; } </style>
效果:
上图中,超链接点击之前是红色,点击之后是绿色。
问:既然a{}定义了超链的属性,和a:link{}都定义了超链点击之前的属性,那这两个有啥区别呢?
答:
a{}和a:link{}的区别:
(2)动态伪类 :
用于以下几种状态:
注意:上面这三种状态针适用于所有的标签。
举例:
<style type="text/css"> /* 伪类选择器:动态伪类 */ /* 让文本框获取焦点时: 边框:#FF6F3D这种橙色 文字:绿色 背景色:#6a6a6a这种灰色 */ input:focus{ border:3px solid #FF6F3D; color:white; background-color:#6a6a6a; } /* 鼠标放在标签上时显示蓝色 */ label:hover{ color:blue; } /* 点击标签鼠标没有松开时显示红色 */ label:active{ color:red; } </style>
效果:
利用这个hover属性,我们同样对表格做一个样式的设置:
表格举例:
<!doctype html><html lang="en"> <head> <meta charset="UTF-8"> <meta name="Generator" content="EditPlus®"> <meta name="Author" content=""> <meta name="Keywords" content=""> <meta name="Description" content=""> <title>Document</title> <style type="text/css"> /*整个表格的样式*/ table{ width: 300px; height: 200px; border: 1px solid blue; /*border-collapse属性:对表格的线进行折叠*/ border-collapse: collapse; } /*鼠标悬停时,让当前行显示#868686这种灰色*/ table tr:hover{ background: #868686; } /*每个单元格的样式*/ table td{ border:1px solid red; } </style> </head> <body> <table> <tr> <td></td> <td></td> <td></td> <td></td> </tr> <tr> <td></td> <td></td> <td></td> <td></td> </tr> <tr> <td></td> <td></td> <td></td> <td></td> </tr> </table> </body></html>
效果:
1、对于相同的选择器,其样式表排序:行级 > 内嵌 > 外部(就近原则)
2、对于相同方式的样式表,其选择器排序:ID选择器 > 类选择器 > 标签选择器
3、外部样式表的ID选择器 > 内嵌样式表的标签选择器
总结:就近原则。ID选择器优先级最大。
举例:如果都是内嵌样式表,优先级的顺序如下:(ID 选择器 > 类选择器 > 标签选择器)
另外还有两个冲突的情况:
1、对同一个标签,如果用到了了多个相同的内嵌样式表,它的优先级: 定义的样式表中,谁最近,就用谁。
2、对于同一个标签,如果引用了多个相同的外部样式表,它的优先级:html文件中,引用样式表的位置越近,就用谁。
例如:
注:本文将持续更新。