ホームページ  >  記事  >  ウェブフロントエンド  >  CSS スタイルのグラフィックとテキストの詳細な説明: css スタイル シートと selector_html/css_WEB-ITnose

CSS スタイルのグラフィックとテキストの詳細な説明: css スタイル シートと selector_html/css_WEB-ITnose

WBOY
WBOYオリジナル
2016-06-24 11:35:561562ブラウズ

メインコンテンツ

  • CSSの概要
  • CSSとHTMLを組み合わせる3つの方法: インラインスタイルシート、埋め込みスタイルシート、外部スタイルシート
  • CSSの4つの基本セレクター: タグセレクター、クラスセレクター、IDセレクター、ユニバーサルselector
  • 3種類のCSS拡張セレクター: 組み合わせセレクター、子孫セレクター、擬似クラスセレクター
  • CSSスタイルの優先順位
  • CSSの概要

    CSS: カスケードスタイルシート、カスケードスタイルシート。 CSS の機能は、HTML ページのタグにさまざまなスタイルを追加し、Web ページの表示効果を定義することです。簡単に言うと、CSSはWebページのコンテンツと表示スタイルを分離し、表示機能を向上させます。 次に、なぜ CSS を使用する必要があるのか​​について話したいと思います。

    HTMLの欠点:

    複数のデバイスに適応できない

    1. インテリジェントで十分な容量のブラウザが必要

    2. データと表示が分離されていない

    3. 十分な能力がない
    CSS利点:

    データと表示を分離する

    1. ネットワークトラフィックを削減する

    2. Webサイト全体の視覚効果を一貫させる

    3. 開発効率を向上させる(カップリングが減少し、1人がHTMLを書く責任を負い、1人がHTMLを書く責任を負います) CSS の記述を担当します)
    4. たとえば、HTML で実装すると、100 回記述する必要があるスタイルがあります。一度書いた。現在、HTML はデータと一部のコントロールのみを提供し、さまざまなスタイルの提供は完全に CSS に任せています。

    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 を組み合わせる方法は、実際には、CSS コードをどこに配置するのがより適切かを尋ねることです。 CSS コードの理論的な位置は任意ですが、通常は c9ccee2e6ea535a969eb3f532ad9fe89 タグ内に記述されます。 c9ccee2e6ea535a969eb3f532ad9fe89 タグ内のコードである限り、それは CSS コードであり、ブラウザーはこれを解析します。

    CSS と HTML を組み合わせる方法は 3 つあります:

    インライン スタイル

    : style 属性を使用します。スコープはこのタグにのみ適用されます

  • 埋め込みスタイルシート
    : c9ccee2e6ea535a969eb3f532ad9fe89 タグで完成します。スコープはこのページに固有です
  • 外部スタイルシートCSSファイルを導入する方法
    。この方法は 2 つのタイプに分かれています:
  • 1. 2cdf5bf648cf2f33323966d7f58a7f3f を使用します。例: d4ab7bbc793c3cba33744f49074f5796f2b8b73da751f6a0101d6acb3acd2296
  • 2. import を使用する場合は、c9ccee2e6ea535a969eb3f532ad9fe89 タグ内に記述する必要があります。そして最初の文でなければなりません。例: @import url(a.css) ; スタイルを導入する 2 つの方法の違い: タグは外部スタイル シートに記述できませんが、インポート ステートメントは記述できます。

    これら 3 つの方法について、以下で詳しく説明します。
  • 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) ;

  • スタイルを導入する 2 つの方法の違い: タグは外部スタイル シートに記述できませんが、インポート ステートメントは記述できます。

    具体操作如下:
    我们先在html页面的同级目录下新建一个a.css文件,那说明这里面的代码全是css代码,此时就没有必要再写c9ccee2e6ea535a969eb3f532ad9fe89标签这几个字了。
    a.css的代码如下:

    p{	border: 1px solid red;	font-size: 40px;}

    上方的css代码中,注意像素要带上px这个单位,不然不生效。
    然后我们在html文件中通过2cdf5bf648cf2f33323966d7f58a7f3f标签引入这个css文件就行了。效果如下:

    这里再讲一个补充的知识:link标签的rel属性
    2cdf5bf648cf2f33323966d7f58a7f3f标签的rel属性:
    其属性值有以下两种:

  • stylesheet:定义的样式表
  • alternate stylesheet:候选的样式表
  • 看字面意思可能比较难理解,我们来举个例子,一下子就明白了。
    举例:
    现在定义我们来定义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要作用的标签,那个标签的名称就是选择器。意为:选择哪个容器。

    CSS的选择器分为两大类:基本选择题和扩展选择器。

    基本选择器:

  • 标签选择器:针对一类标签
  • 类选择器:针对你想要的所有标签使用
  • ID选择器:针对特定的一个标签使用
  • 通用选择器:针对所有的标签都适用
  • 下面来分别讲一讲。

    1、标签选择器:选择器的名字代表html页面上的标签

    可以匹配针对一类标签。

    举例:

    p{	font-size:14px;}

    上方选择器的意思是说:所有的e388a4556c0f65e1904146cc1a846bee标签里的内容都将显示14号字体。
    效果:

    2、类选择器:规定用圆点.来定义

    优点:灵活。

    举例:

    .one{	width:800px;}

    效果:

    3、ID选择器:规定用#来定义

    针对特定的一个标签来使用,只能使用一次。ID选择器以”#”来定义。
    举例:

    #mytitle{	border:3px dashed green;}

    效果:

    上面这三种选择器的区别:

  • 标签选择器针对的是页面上的一类标签。
  • 类选择器可以供多种标签使用。
  • ID选择器是值供特定的标签(一个),ID是此标签在此页面上的唯一标识。
  • 4、通用选择器: 用*定义,将匹配任何标签

    通用选择器,将匹配任何标签。不建议使用,IE有些版本不支持,大网站增加客户端负担。
    举例:

    *{	margin-left:0px;	margin-top:0px;}

    效果:

    CSS的三种扩展选择器

    扩展选择器:

  • 组合选择器:采用逗号隔开
  • 关联选择器(后代选择器):采用空格隔开
  • 伪类选择器
  • 下面详细讲一下这三种扩展选择器。

    1、组合选择器:定义的时候用逗号隔开

    三种基本选择器都可以放进来。

    举例:

    p,h1,.one,#mytitle{	color:red;}

    效果:

    2、关联选择器(后代选择器): 定义的时候用空格隔开

    对于E F这种格式,表示限定所有属于E元素后代的F元素有这个样式。
    看定义可能有点难理解,我们来看例子吧。

    举例:

    h3 b i{	color:red ; } 

    上方代码的意思是说:定义了3f7b3decd2dcafb07b84d2d3985d9f40标签中的a4b561c25d9afb9ac8dc4d70affff419标签中的5a8028ccc7a7e27417bff9f05adf5932标签的样式。
    注:h3和b和i标签不一定是连续紧挨着的,只要保持一个后代的关联即可。

    效果:

    或者还有下面这种写法:

    上面的这种写法,684271ed9684bde649abda8831d4d355标签和5a8028ccc7a7e27417bff9f05adf5932标签并不是紧挨着的,但他们保持着一种后代关系。

    还有下面这种写法:(含类选择器、id选择器都是可以的)

    3、伪类选择器

    对于3499910bf9dac5ae3c52d5ede7383485标签,其对应几种不同的状态:

  • link:超链接点击之前
  • visited:超链接点击之后
  • focus:是某个标签获得焦点的时候(比如某个输入框获得焦点)
  • hover:鼠标放到某个标签上的时候
  • active:点击某个标签没有松鼠标时
  • CSS允许对于元素的不同状态,定义不同的样式信息。伪类选择器又分为两种:

  • 静态伪类:只能用于超链接
  • 动态伪类:针对所有标签都适用
  • 下面来分别讲一下这两种伪类选择器。

    (1)静态伪类:
    用于以下两个状态:

  • link:超链接点击之前
  • visited:超链接点击之后
  • 注意:上面这两个状态只能使用于超链接

    举例:

      <style type="text/css">  /*	伪类选择器:静态伪类  */   /*	让超链接点击之前是红色   */	a:link{		color:red; 	}	/*	让超链接点击之后是绿色    */	a:visited{		color:green; 	}  </style>

    效果:

    上图中,超链接点击之前是红色,点击之后是绿色。

    问:既然a{}定义了超链的属性,和a:link{}都定义了超链点击之前的属性,那这两个有啥区别呢?
    答:
    a{}和a:link{}的区别:

  • a{}定义的样式针对所有的超链接(包括括锚点)
  • a:link{}定义的样式针对所有写了href属性的超链接(不包括锚点)
  • (2)动态伪类 :

    用于以下几种状态:

  • focus:是某个标签获得焦点的时候(比如某个输入框获得焦点)
  • hover:鼠标放到某个标签上的时候
  • active:点击某个标签没有松鼠标时
  • 注意:上面这三种状态针适用于所有的标签。

    举例:

      <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&reg;">  <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>

    效果:

    CSS样式表的冲突解决

    1、对于相同的选择器,其样式表排序:行级 > 内嵌 > 外部(就近原则)
    2、对于相同方式的样式表,其选择器排序:ID选择器 > 类选择器 > 标签选择器
    3、外部样式表的ID选择器 > 内嵌样式表的标签选择器

    总结:就近原则。ID选择器优先级最大。

    举例:如果都是内嵌样式表,优先级的顺序如下:(ID 选择器 > 类选择器 > 标签选择器)

    另外还有两个冲突的情况:
    1、对同一个标签,如果用到了了多个相同的内嵌样式表,它的优先级: 定义的样式表中,谁最近,就用谁。
    2、对于同一个标签,如果引用了多个相同的外部样式表,它的优先级:html文件中,引用样式表的位置越近,就用谁。

    例如:

    注:本文将持续更新。

    声明:
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。