ホームページ  >  記事  >  ウェブフロントエンド  >  【CSSメモ10】CSSスタイル設定のヒント

【CSSメモ10】CSSスタイル設定のヒント

黄舟
黄舟オリジナル
2016-12-29 14:02:291030ブラウズ

1. 水平方向のセンタリング設定: インライン要素
実際の仕事では、見た目を美しくするために、記事のタイトルを水平方向に中央に表示することがよくあります。

ここでは、インライン要素とブロック要素の 2 つの異なる状況があります。ブロック要素は、固定幅のブロック要素と可変幅のブロック要素に分割されます。今日はまず、インライン要素を水平方向に中央揃えする方法を学びます。

設定した要素がtextやpictureなどのインライン要素の場合、親要素にtext-align:centerを設定することで水平方向のセンタリングが実現されます。 (親要素と子要素:以下のHTMLコードのように、「親コンテナ内で横並びに中央揃えで表示したい」というテキストの親要素はdivです。逆に、このテキストはdivの子要素です)以下のコード:

html コード:

<body> <div class="txtCenter">我想要在父容器中水平居中显示。</div> </body>
css代码:
<style> .txtCenter{ text-align:center; } </style>

2. 水平方向のセンタリング設定: 固定幅ブロック要素
設定する要素がブロック要素の場合、現時点では text-align: center は機能しません。これには、固定幅のブロック要素と可変幅のブロック要素の 2 つの状況があります。

このセクションでは、まず固定幅のブロック要素について説明します。 (固定幅ブロック要素:ブロック要素の幅が固定値です。)

固定幅とブロックの2つの条件を満たす要素は、「左右マージン」の値を「自動」に設定することで中央揃えにすることができます。 div ブロック要素を水平方向の中央に設定する例を見てみましょう:

html コード:

<body> <div>我是定宽块状元素,哈哈,我要水平居中显示。</div> </body>
css代码:
<style> div{ border:1px solid red;/*为了显示居中效果明显为 div 设置了边框*/ width:200px;/*定宽*/ 
margin:20px auto;/* margin-left 与 margin-right 设置为 auto */ } </style>

次のように書くこともできます:

margin-left:auto; margin-right:auto;

注: 要素の「上下のマージン」は、次の場所で設定できます。意思。

3. 水平方向のセンタリングのまとめ: 可変幅ブロック要素の方法 1

実際の作業では、Web ページのページング ナビゲーションなどの「可変幅ブロック要素」の中心を設定する必要に遭遇します。ページングの数は未定義であるため、幅を設定することでその弾力性を制限することはできません。 (可変幅ブロック要素: ブロック要素の幅は固定されていません。)

可変幅のブロック要素を中央に配置するには 3 つの方法があります (これら 3 つの方法は現在よく使用されています):

1. table タグを追加します。 2 . 表示の設定: インラインメソッド: 最初のメソッドと同様に、表示タイプをインライン要素に設定し、可変幅要素の属性を設定します。
3. 相対位置を使用して移動します。要素を左側に 50% オフセットします。つまり、中央揃えの目的を達成するためです。

このセクションでは、最初の方法について説明します。

table タグを追加する方法 1 を選択する理由は、長さの適応性を使用するためです。 table タグ - つまり、その長さは定義されておらず、デフォルトの親要素本体の長さも定義されていないため (テーブルの長さはその中のテキストの長さによって決まります)、次のようにみなすことができます。固定幅ブロック要素の場合、固定幅ブロック中央マージン法を使用して水平方向の中央揃えが行われます。

ステップ 1: 設定する必要がある中央の要素の外側に table タグ (92cee25da80fac49f6fb6eec5fd2c22a、a34de1251f0d9fe1e645927f19a896e8、b6c5a531a458a2e790c1fd6421739d1c を含む) を追加します。

ステップ2: この表の「左右のマージンを中央に設定」します(これは固定幅ブロック要素と同じ方法です)。

例は次のとおりです:

html コード:

<div> <table> <tbody> <tr><td> <ul> <li>我是第一行文本</li> <li>我是第二行文本</li> <li>我是第三行文本</li> </ul> </td></tr> </tbody> </table> </div>

css コード:


<style> table{ border:1px solid; margin:0 auto; } </style>

4. 水平方向のセンタリングの概要: 可変幅ブロック要素の方法 2

前のセクションで説明したテーブル タグの挿入に加えて、次のようにすることもできます。可変幅ブロック このセクションでは、要素を水平方向に中央揃えすることに加えて、この効果を実現する 2 番目の方法を紹介します。それは、要素の表示タイプをインライン要素に変更し、その属性を使用して直接設定することです。

2 番目の方法: ブロックレベル要素の表示タイプをインラインタイプに変更し (インライン要素表示に設定)、text-align:center を使用してセンタリング効果を実現します。次の例:

html コード:

<body> <div class="container"> <ul> <li><a href="#">1</a></li> <li><a href="#">2</a></li><li><a href="#">3</a></li> </ul> </div> </body>

css コード:


<style> 
.container{ text-align:center; } /* margin:0;padding:0(消除文本与div边框之间的间隙)*/ 
.container ul{ list-style:none; margin:0; padding:0; display:inline; } /* margin-right:8px(设置li文本之间的间隔)*/ 
.container li{ margin-right:8px; display:inline; } 3
</style>

最初の方法と比較したこの方法の利点は、非セマンティックなタグを追加する必要がないことですが、いくつかの問題もあります。ブロック要素の表示 型が inline に変更され、インライン要素となるため、長さの値の設定などの一部の機能がありません。


3. 水平方向の中央揃えの概要: 可変幅のブロック要素の方法 3

前の 2 つのセクションで説明したテーブル タグの挿入と要素の表示タイプの変更に加えて、可変幅のブロック要素を水平方向に中央揃えにすることができます。この効果を実現する 3 番目の方法は、フローティングおよび相対位置を設定することです。

方法 3: 親要素に float を設定し、次に親要素にposition:relativeおよびleft:50%を設定し、子要素にposition:relativeおよびleft:-50%を設定して、水平方向のセンタリングを実現します。

次のように理解できます: ul レイヤーの親レイヤー (つまり、以下の例では div レイヤー) の中央に、ul レイヤーの親レイヤー (div レイヤー) を分割する二等分線があると仮定します。 ) を 2 つの部分に分割します。 ul レイヤーの左端は ul レイヤーの親レイヤー (div レイヤー) の二等分線に揃えられ、li レイヤーの css コードは li の二等分線に揃えられます。これにより、li レイヤーの中心が決まります。

コードは次のとおりです:

<body> <div class="container"> <ul> <li><a href="#">1</a></li> <li><a href="#">2</a></li><li><a href="#">3</a></li> </ul> </div> </body>

css コード:


<style> 
.container{ float:left; position:relative; left:50% } 
.container ul{ list-style:none; margin:0; padding:0; position:relative; left:-50%; } 
.container li{ float:left; display:inline; margin-right:8px; } 
</style>

これら 3 つの方法は広く使用されており、それぞれに独自の長所と短所があります。どの方法を選択するかは、特定の状況によって異なります。


六、垂直居中:父元素高度确定的单行文本 
我们在实际工作中也会遇到需要设置垂直居中的场景,比如好多报纸的文章标题在左右一侧时,常常会设置为垂直居中,为了用户体验性好。

这里我们又得分两种情况:父元素高度确定的单行文本,以及父元素高度确定的多行文本。

本节我们先来看第一种父元素高度确定的单行文本, 怎么设置它为垂直居中呢?

父元素高度确定的单行文本的竖直居中的方法是通过设置父元素的 height 和 line-height 高度一致来实现的。(height: 该元素的高度,line-height: 顾名思义,行高(行间距),指在文本中,行与行之间的 基线间的距离 )。

line-height 与 font-size 的计算值之差,在 CSS 中成为“行间距”。分为两半,分别加到一个文本行内容的顶部和底部。

这种文字行高与块高一致带来了一个弊端:当文字内容的长度大于块的宽时,就有内容脱离了块。

如下代码:

<div class="container"> hi,imooc! </div>

css代码:

<style> .container{ height:100px; line-height:100px; background:#999; } </style>

七、垂直居中:父元素高度确定的多行文本一 
父元素高度确定的多行文本、图片等的竖直居中的方法有两种:

方法一:使用插入 table (包括tbody、tr、td)标签,同时设置 vertical-align:middle。

css 中有一个用于竖直居中的属性 vertical-align,在父元素设置此样式时,会对inline-block类型的子元素都有用。下面看一下例子:

html代码:

<body> <table><tbody><tr><td class="wrap"> <div> <p>看我是否可以居中。</p> </div> </td></tr></tbody></table> </body>

css代码:

table td{height:500px;background:#ccc}

因为 td 标签默认情况下就默认设置了 vertical-align 为 middle,所以我们不需要显式地设置了。

八、垂直居中:父元素高度确定的多行文本二 
除了上一节讲到的插入table标签,可以使父元素高度确定的多行文本垂直居中之外,本节介绍另外一种实现这种效果的方法。但这种方法兼容性比较差,只是提供大家学习参考。

在 chrome、firefox 及 IE8 以上的浏览器下可以设置块级元素的 display 为 table-cell(设置为表格单元显示),激活 vertical-align 属性,但注意 IE6、7 并不支持这个样式, 兼容性比较差。

html代码:

<div class="container"> <div> <p>看我是否可以居中。</p> <p>看我是否可以居中。</p> <p>看我是否可以居中。</p> </div> </div>

css代码:

<style> .container{ height:300px; background:#ccc; display:table-cell;/*IE8以上及Chrome、Firefox*/ vertical-align:middle;/*IE8以上及Chrome、Firefox*/ } </style>

这种方法的好处是不用添加多余的无意义的标签,但缺点也很明显,它的兼容性不是很好,不兼容 IE6、7而且这样修改display的block变成了table-cell,破坏了原有的块状元素的性质。

九、隐性修改display类型 
有一个有趣的现象就是当为元素(不论之前是什么类型元素,display:none 除外)设置以下 2 个句之一:

position : absolute
float : left 或 float:right

简单来说,只要html代码中出现以上两句之一,元素的display显示类型就会自动变为以 display:inline-block(块状元素)的方式显示,当然就可以设置元素的 width 和 height 了,且默认宽度不占满父元素。

如下面的代码,小伙伴们都知道 a 标签是 行内元素 ,所以设置它的 width 是 没有效果的,但是设置为 position:absolute 以后,就可以了。

<div class="container"> <a href="#" title="">进入课程请单击这里</a> </div>

css代码

<style> .container a{ position:absolute; width:200px; background:#ccc; } </style>

 以上就是【CSS笔记十】CSS样式设置小技巧的内容,更多相关内容请关注PHP中文网(www.php.cn)!


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