ホームページ  >  記事  >  ウェブフロントエンド  >  CSSボックスモードを徹底理解(DIVレイアウトでクイックスタート)(再版)_html/css_WEB-ITnose

CSSボックスモードを徹底理解(DIVレイアウトでクイックスタート)(再版)_html/css_WEB-ITnose

WBOY
WBOYオリジナル
2016-06-24 12:28:10915ブラウズ

原文: http://www.hsptc.com/css2.html
http://www.hsptc.com/articles/index.html

CSSボックスモードを徹底理解(DIVレイアウトでクイックスタート) はじめに

著者 : Tang Guohui Tianya Community、Classic Forum ニックネーム: webflash

Web ページのレイアウトにテーブルを使用するのではなく、DIV を使用して Web ページをレイアウトするというよく聞く CSS を使用して Web ページをレイアウトしたい場合Web の標準デザインを学びたい、または企業の競争力を向上させるために従来のテーブル レイアウト方法を変更するよう上司から求められている場合、知っておく必要がある知識ポイントの 1 つは、DIV の中核である CSS ボックス モードです。従来のテーブル レイアウトでは、さまざまなサイズのテーブルとテーブルのネストを使用して、Web ページのコンテンツを配置およびレイアウトします。CSS レイアウトに切り替えた後、Web ページは、CSS で定義されたさまざまなサイズのボックスとボックス ネストを介して配置されます。この方法で入力された Web ページのコードはシンプルで更新が簡単で、PDA デバイスなどのより多くのブラウザと互換性があり、通常に閲覧することもできるため、大好きだった表組版をあきらめる価値があります。さらに重要なのは、Web ページの CSS 組版の利点はここでは詳しく説明しません。関連する情報は自分で見つけることができます。

CSS ボックス モデルを理解する

CSS ボックス モデルとは何ですか?なぜボックスと呼ばれるのですか?まず、Web デザインでよく聞く属性名について説明します。content、padding、border、margin はすべてこれらの属性を持ちます。 CSS ボックス モードのこれらの性質を、日常生活で目にするボックス (ボックス) に置き換えることで理解できるため、ボックス モードと呼ばれます。中身とは箱の中にあるものであり、中身(貴重品)の損傷を防ぐために追加された発泡体やその他の耐震補助材料のことです。通気性と取り外しを容易にするために、一定の隙間をあけて積み重ねてください。 Web デザインでは、コンテンツはテキスト、画像、その他の要素を指すことがよくありますが、実際のボックスとは異なり、小さなボックス (DIV ネスト) の場合もあります。一般に、現実のものはボックスよりも大きくすることはできません。そうしないと、ボックスが引き伸ばされてしまいます。壊れています。CSS ボックスは弾力性があり、中の物はボックス自体より大きく、せいぜい伸びますが、破損することはありません。塗りつぶしには幅属性のみがあり、これは生活の箱の耐震補助材の厚さとして理解できますが、境界線にはサイズと色があり、これは生活の中で見る箱の厚さとして理解できます箱が何色の素材でできているか、境界線は箱と他の物との間の距離です。現実の世界では、私たちが正方形の中にいて、さまざまなサイズと色のボックスを一定の間隔で、一定の順序で配置するとします。最後に、広場から見下ろすと、やりたいことと同じようなグラフィックや構造が見えるでしょう。 . Web ページのレイアウトは次のように設計されています。 「ボックス」によって積み上げられた Web ページのレイアウト

CSS ボックス パターンをどの程度理解していますか? 十分に理解できていない場合は、後で例を挙げて説明します。

考え方を変えましょう

従来のフロントエンド Web デザインは次のように実行されます。要件に従って、まずメインカラー、使用する画像の種類、フォント、色などを検討し、次に次のようなソフトウェアを使用します。 Photoshop で自由に描画し、最終的には小さな画像に切り出すことができます。CSS に切り替えてからは、この考え方を変更する必要があります。強力な CSS コントロールにより、ページ コンテンツのセマンティクスと構造を制御できます。Web ページが完成した後、必要な Web ページ スタイルを簡単に調整できます。さらに、CSS レイアウトのもう 1 つの目的は、コードを読みやすくし、ブロックをクリアすることです。コードの再利用を強化するため、構造は非常に重要です。私の Web ページのデザインが非常に複雑であると言いたい場合、後でその効果を実現することは可能ですか?私が言いたいのは、CSS で実現できない効果をテーブルで実現するのは一般に難しいということです。CSS の制御能力は強力すぎるためです。ところで、CSS を使用することには非常に実用的な利点があります。組版の場合、Webサイトの構築を受注している場合、WebページのレイアウトにCSSを使用している場合、後で顧客が不満を感じた場合、特に色調を変更するのは非常に簡単で、カスタマイズすることもできます。顧客が選択するか、動的呼び出しを実装するプログラムを作成して、Web サイトにスタイルを動的に変更する機能を持たせることができます。

構造とプレゼンテーションの分離を実現する

実際のレイアウトの練習を始める前に、もう 1 つ知っておいてください。これも CSS レイアウトの特性を利用しています。構造とプレゼンテーションを分離した後のコードは次のようになります。簡潔で更新が便利になるのが CSS を学ぶ目的ではないでしょうか。たとえば、P タグがある場合、これは段落ブロックであることを示します。段落を 2 文字分右インデントしたいと考える人もいるでしょう。スペースを追加して続行 スペースが追加されますが、P タグの CSS スタイル: P {text-indent: 2em;} を指定できるようになり、追加のパフォーマンス制御タグなしで、結果の本文コンテンツは次のようになります:

加进天涯社区有一段时间了,但一直没有时间写点东西,今天写了一篇有关CSS布局的文章,并力求通过一种通俗的语言来说明知识点,还配以实例和图片,相信对初学CSS布局的人会带来一定的帮助。

如果还要对这个段落加上字体、字号、背景、行距等修饰,直接把对应的CSS加进P样式里就行了,不用像这样来写了:

段落内容

这个是结构和表现混合一起写的,如果很多段落有统一结构和表现的话,再这样累加写下去代码就繁冗了。

再直接列一段代码加深理解结构和表现相分离:
用CSS排版







不用CSS排版





第一种方法是结构表现相分离,内容部分代码简单吧,如果还有更多的图片列表的话,那么第一种CSS布局方法就更有优势,我打个比喻你好理解:我在BODY向你介绍一个人,我只对你说他是一个人,至于他是一个什么样的人,有多高,是男是女,你去CSS那里查下就知道。这样我在BODY的工作就简单了,也就是说BODY的代码就简单了。如果BODY有一个团队人在那里,我在CSS记录一项就行了,这有点像Flash软件里的元件和实例的概念,不同的实例共享同一个元件,这样动画文件就不大了,把这种想法移到CSS网页设计中,就是代码不复杂,网页文件体积小能较快被客户端下载了。演示地址:http://www.hsptc.com/css1.html用CSS排版减小网页文件体积

像上面我做的那个版面,一共分为四个区块,每个区块的框架是一样的,这个框架就是用CSS写出来的,样式写一次,就可以被无数次调用了(用class调用,而不是ID),只要改变其中的文字内容就可以生成风格统一的众多板块了,它的样式和结构代码是(请不要直接复制生成网页,把下面代码分别粘贴到网页中它们应在的位置):



前言


正文内容




CSS盒子模式


正文内容




转变思想


正文内容




熟悉步骤


正文内容


熟悉工作流程

在真正开始工作之前我们脑海中要形成这样一种思想:表格是什么我不知道,在内容部分我不能让它再出现表现控制标签,如:font、color、height、width、align等标签不能再出现,(简单说工作前先洗脑,忘掉以前的一惯做法,去接受和使用全新的方法),我不是单纯的用DIV来实现排版的嵌套,DIV是块级元素,而像P也是块级元素,例如要分出几个文字内容块,不是一定要用DIV才叫DIV排版,不是“

文字块一
文字块二
文字块三
”,而用“

文字块一

文字块二

文字块三

”更合适。

用DIV+CSS设计思路是这样的: 1.用div来定义语义结构;2.然后用CSS来美化网页,如加入背景、线条边框、对齐属性等;3.最后在这个CSS定义的盒子内加上内容,如文字、图片等(没有表现属性的标签),下面大家跟我一起来做一个实例加深对这个步骤的理解。先看结果图:演示地址:http://www.hsptc.com/css2.htmlCSS排版结果图

用div来定义语义结构

现在我要给大家演示的是一个典型的版面分栏结构,即页头、导航栏、内容、版权(如下图),典型版面分栏结构其结构代码如下:




上面我们定义了四个盒子,按照我们想要的结果是,我们要让这些盒子等宽,并从下到下整齐排列,然后在整个页面中居中对齐,为了方便控制,我们再把这四个盒子装进一个更大的盒子,这个盒子就是BODY,这样代码就变成:






最外边的大盒子(装着小盒子的大盒子)我们要让它在页面居中,并重定义其宽度为760像素,同时加上边框,那么它的样式是:

body {
font-family: Arial, Helvetica, sans-serif;
font-size: 12px;
margin: 0px auto;
height: auto;
width: 760px;
border: 1px solid #006633;
}

页头为了简单起见,我们这里只要让它整个区块应用一幅背景图就行了,并在其下边界设计定一定间隙,目的是让页头的图像不要和下面要做的导航栏连在一起,这样也是为了美观。其样式代码为:

#header {
height: 100px;
width: 760px;
background-image: url(headPic.gif);
background-repeat: no-repeat;
margin:0px 0px 3px 0px;
}

导航栏我做成像一个个小按钮,鼠标移上去会改变按钮背景色和字体色,那么这些小小的按钮我们又可以理解为小盒子,如此一来这是一个盒子嵌套问题了,样式代码如下:

#nav {
height: 25px;
width: 760px;
font-size: 14px;
list-style-type: none;
}
#nav li {
float:left;
}
#nav li a{
color:#000000;
text-decoration:none;
padding-top:4px;
display:block;
width:97px;
height:22px;
text-align:center;
background-color: #009966;
margin-left:2px;
}
#nav li a:hover{
background-color:#006633;
color:#FFFFFF;
}

内容部分主要放入文章内容,有标题和段落,标题加粗,为了规范化,我用H标签,段落要自动实现首行缩进2个字,同时所有内容看起来要和外层大盒子边框有一定距离,这里用填充。内容区块样式代码为:

#content {
height:auto;
width: 740px;
line-height: 1.5em;
padding: 10px;
}
#content p {
text-indent: 2em;
}
#content h3 {
font-size: 16px;
margin: 10px;

版权栏,给它加个背景,与页头相映,里面文字要自动居中对齐,有多行内容时,行间距合适,这里的链接样式也可以单独指定,我这里就不做了。其样式代码如下:

#footer {
height: 50px;
width: 740px;
line-height: 2em;
text-align: center;
background-color: #009966;
padding: 10px;
}

最后回到样式开头大家会看到这样的样式代码:

* {
margin: 0px;
padding: 0px;
}

这是用了通配符初始化各标签边界和填充,(因为有部分标签默认会有一定的边界,如Form标签)那么接下来就不用对每个标签再加以这样的控制,这可以在一定程度上简化代码。最终完成全部样式代码是这样的:

结构代码是这样的:





序文


コンテンツの最初の段落< /p>

CSS ボックス モードについて


コンテンツの 2 番目の段落





それでは、この記事はここで終わります。CSS でのボックスの幅の計算、ブラウザーの互換性の問題、XHTML などのその他のコンテンツ。標準化された記述などについては、他の資料を参照してください。この記事が良いと思われる場合は、読んだ後にコメントを残すことを忘れないでください。あなたの励ましが私が新しい記事を公開し続ける原動力です^-^

抜粋を転載することは歓迎です。著者!著者: 唐国輝

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