在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
都说用 DIV+CSS 布局来设计网站便于优化,容易被收录,那么你对 DIV+CSS 布局的用法是否了解?CSS 布局是网页html通过 DIV 标签 +CSS 样式表代码开发制作的(html)网页的统称。DIV+CSS 布局是现在非常流行的布局方法,替代了原来的表格布局。下面我们先来看下学习 DIV+CSS 布局的基本步骤:
一、认清学习的要求 制作DIV CSS网页前思考布局:
首先我们拿到一张网页美工图片我们将从上下、上中下、左右、上中(中包括左右)下布局框架来思考。
下面通过一个实例讲解下 CSS 布局分析,我们以 DIV CSS5 列表页面分析 CSS 布局:
首先我们可以分析出我们 DIV CSS 布局重构此页面结构框架,我们可以看出是上、中、下结构,其中又包括了左右结构。
由此我们就要写此页面 CSS 和 html 时候就先从上到下从外到内原则写 CSS 与 html。 我们首先建一个 web 的文件夹并在此文件夹里新建 html 页面命名为 index.html,CSS 文件命名为index.css。这里有个诀窍就是可以导入模板方式来建 CSS 与 html 初始页面,然后将 CSS 文件引用到 html,再在 CSS 模板的基础上再写再添加 CSS。 以下是 index.html 的 html 代码:
以下为引用的内容:
实例<div id="header">我是头部(上)</div> <div id="centers"> <div class="c_left">我是中的左</div> <div class="c_right">我是中的右</div> <div class="clear"> </div> </div> <div id="footer">我是底部(下)</div> 尝试一下 » index.css 的CSS代码如下:
以下为引用的内容: body,div,address,blockquote,iframe,ul,ol,dl,dt,dd,li,dl,h1,h2,h3,h4,h5,h6,p,pre,table, caption,th,td,form,legend,fieldset,input,button,select,textarea{margin:0;padding:0; font-weight:normal;font-style:normal;font-size:100%;font-family:inherit;} ol,ul,li{list-style:none;} img{border:0;} body{color:#000;background:#FFF;text-align:center;font:12px/1.5Arial,Helvetica,sans-serif;} .clearfix:after{clear:both;content:".";display:block;height:0pt;visibility:hidden;overflow:hidden;} .clear{clear:both;height:1px;margin-top:-1px;width:100%;} .dis{display:block;} .undis{display:none;} /*此上面代码是初始CSS模板,下面是新写CSS布局框架代码*/ #header,#centers,#footer{width:100%;margin:0auto; clear:both;font-size:18px;line-height:68px;font-weight:bold;} #header{height:68px;border:1px solid #CCCCCC;} #centers{padding:8px0;} #footer{border-top:1px solid #CCCCCC;background:#F2F2F2;} #centers.c_left{float:left;width:230px;border:1px solid #00CC66; background:#F7F7F7;margin-right:5px;} #centers.c_right{float:right;width:500px;border:1px solid #00CC66;background:#F7F7F7} 你可以考出此两段代码新建个试试。
按以下步骤来建设一个网站的页面:1、顶部部分,其中包括了LOGO、MENU和一幅Banner图片;2、页面中间部分,那就是我们的主体了,要求打开首页快速,所以我们在网站发布的信息设计为三列。 3、底部,包括一些版权信息。 根据以上设想,我们定义如下 div 的结构 DIV结构如下:
│body {} /*这是一个HTML元素*/ └#Container {} /*页面层容器*/ ├#Header {} /*页面头部*/ ├#MianBody {} /*页面主体*/ │ ├#mainbody-left {} /*主体页面左边*/ │ └#mainbody-center {} /*主体页面中间*/ │ └#MainBody -right{} /*主体页面右边*/ └#footer {} /*页面底部*/ 用 DIV+CSS 做一个导航栏是非常容易的,而且我们可以通过 CSS 来对导航栏的样式方便的作出调整。用div设置导航栏一般就用<ul>和<li>标签。 4、高度显示效果不同 一般情况下只需要使用 height: 100px; 即可,当显示效果不同时,则可以 _height: 100px; 来对 IE6 的高度进行设置。 5、嵌套效果不同. 有些情况下如果 div 中嵌套的图片大于外层 div 的高度,则 IE6 中对高度的设置始终无效,这时要注意对该css添加 overflow 属性,overloaw:hidden,则可隐藏超出边界的部分。 DIV+CSS网页布局常用的一些基础知识整理一.文件命名规范 全局样式:global.css;
页 眉:header
CSS书写规范及方法一. 常规书写规范及方法 1. 选择 DOCTYPE: XHTML 1.0 提供了三种DTD声明可供选择: 过渡的(Transitional):要求非常宽松的 DTD,它允许你继续使用 HTML4.01 的标识(但是要符合 xhtml 的写法)。完整代码如下: XML/HTML代码
严格的(Strict):要求严格的 DTD,你不能使用任何表现层的标识和属性,例如<br>。完整代码如下: XML/HTML 代码
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Strict//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd“> 框架的(Frameset):专门针对框架页面设计使用的 DTD,如果你的页面中包含有框架,需要采用这种 DTD。完整代码如下:
XML/HTML代码
<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Frameset//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd“> 为文档指定语言: XML/HTML代码 <html xmlns=”http://www.w3.org/1999/xhtml” lang=”en”> 为了被浏览器正确解释和通过W3C代码校验,所有的XHTML文档都必须声明它们所使用的编码语言; 如常用的语言定义:
XML/HTML代码
<meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″ /> 标准的XML文档语言定义:
XML/HTML代码
<?xml version=”1.0″ encoding=” utf-8″?> 针对老版本的浏览器的语言定义:
XML/HTML代码
<meta http-equiv=”Content-Language” content=” utf-8″ /> 为提高字符集,建议采用“utf-8”。
3. 调用样式表:
XML/HTML代码
<style type=”text/css”><!– body { background : white ; color : black ; } –> </style> 外部调用法:将样式表写在一个独立的 .css 文件中,然后在页面 head 区用类似以下代码调用。 XML/HTML代码
<link rel=”stylesheet” rev=”stylesheet” href=”css/style.css” type=”text/css” media=”all” /> 在符合 web 标准的设计中,推荐使用外部调用法,可以不修改页面只修改.css文件而改变页面的样式。如果所有页面都调用同一个样式表文件,那么改一个样式表文件,可以改变所有文件的样式。
XML/HTML代码
.mainMenu ul li {background:url(images/bg.gif;)} 6、辅助图片用背影图处理:
这里的”辅助图片”是指那些不是作为页面要表达的内容的一部分,而仅仅用于修饰、间隔、提醒的图片。将其做背影图处理,可以在不改动页面的情况下通过CSS样式来进行改动,如:
XML/HTML代码
#logo {background:url(images/logo.jpg) #FEFEFE no-repeat right bottom;}
7、结构与样式分离:
XML/HTML代码
实例#mainMenu { width:100%; height:30px; background:url(images/mainMenu_bg.jpg) repeat-x; } #mainMenu ul li { float:left; line-height:30px; margin-right:1px; cursor:pointer; } 尝试一下 »
9、鼠标手势:
XML/HTML代码
.search{ border:1px solid #fff;/*定义搜索输入框边框*/ background:url(../images/icon.gif) no-report #333;/*定义搜索框的背景*/ }
2、整段注释:
XML/HTML代码
/*=====搜索条=====*/ .search { border:1px solid #fff; background:url(../images/icon.gif) no-repeat #333; } /*=====搜索条结束=====*/ 三.样式属性代码缩写
XML/HTML代码
#mainMenu { background:url(../images/bg.gif); border:1px solid #333; width:100%; height:30px; overflow:hidden; } #subMenu { background:url(../images/bg.gif); border:1px solid #333; width:100%; height:20px; overflow:hidden; } 两个不同类的属性值有重复之处,刚可以缩写为: XML/HTML代码
#mainMenu,#subMenu { background:url(../images/bg.gif); border:1px solid #333; width:100%; overflow:hidden; } #mainMenu {height:30px;} #subMenu {height:20px;} 2、同一属性的缩写:
XML/HTML代码
.search { background-color:#333; background-image:url(../images/icon.gif); background-repeat: no-repeat; background-position:50% 50%; } .search { background:#333 url(../images/icon.gif) no-repeat 50% 50%; } 在CSS中关于内外侧边框的距离是按照上、右、下、左的顺序来排列的,当这四个属性值不同时也可直接缩写,如:
XML/HTML代码
.btn { margin-top:10px; margin-right:8px; margin-bottom:12px; margin-left:5px; padding-top:10px; padding-right:8px; padding-bottom:12px; padding-left:8px; } 则可缩写为:
XML/HTML代码
.btn { Margin:10px 8px 12px 5px; Padding:10px 8px 12px 5px; } 而如果当上边与下边、左边与右边的边框属性值相同时,则属性值可以直接缩写为两个,如:
.btn { margin-top:10px; margin-right:5px; margin-bottom:10px; margin-left:5px; } XML/HTML代码
缩写为:
XML/HTML代码
.btn {margin:10px 5px;} 而当上下左右四个边框的属性值都相同时,则可以直接缩写成一个,如: XML/HTML代码
.btn { margin-top:10px; margin-right:10px; margin-bottom:10px; margin-left:10px; } 缩写为:
XML/HTML代码
.btn{margin:10px;} 4、颜色值的缩写:
XML/HTML代码
.menu { color:#ff3333;} 可缩写为:
XML/HTML代码
.menu {color:#f33;} 1、 IE6、IE7、Firefox之间的兼容写法:
XML/HTML代码
IE都能识别*;标准浏览器(如FF)不能识别*; IE6能识别*,但不能识别 !important, IE7能识别*,也能识别!important; FF不能识别*,但能识别!important; 根据上述表达,同一类/ID下的CSS hack可写为: .searchInput { background-color:#333;/*三者皆可*/ *background-color:#666 !important; /*仅IE7*/ *background-color:#999; /*仅IE6及IE6以下*/ } 一般三者的书写顺序为:FF、IE7、IE6.
XML/HTML代码
.searchInput { background-color:#333;/*通用*/ _background-color:#666;/*仅IE6可识别*/ }
写法三:
XML/HTML代码
*+html 与 *html 是IE特有的标签, Firefox 暂不支持。 .searchInput {background-color:#333;} *html .searchInput {background-color:#666;}/*仅IE6*/ *+html .searchInput {background-color:#555;}/*仅IE7*/
屏蔽IE浏览器:
XML/HTML代码
*:lang(zh) select {font:12px !important;} /*FF的专用*/ select:empty {font:12px !important;} /*safari可见*/
IE6可识别:
XML/HTML代码
select { display /*IE6不识别*/:none;}
IE的if条件hack写法:
XML/HTML代码
<!–[if IE]> Only IE <![end if]–> 只有IE5.0可以识别: <!–[if IE 5.0]> Only IE 5.0 <![end if]–> IE5.0包换IE5.5都可以识别: <!–[if gt IE 5.0]> Only IE 5.0+ <![end if]–> 仅IE6可识别: <!–[if lt IE 6]> Only IE 6- <![end if]–> IE6以及IE6以下的IE5.x都可识别: <!–[if gte IE 6]> Only IE 6/+ <![end if]–> 仅IE7可识别: <!–[if lte IE 7]> Only IE 7/- <![end if]–> 在 Firefox 中,当子级都为浮动时,那么父级的高度就无法完全的包住整个子级,那么这时用这个清除浮动的 HACK 来对父级做一次定义,那么就可以解决这个问题。
XML/HTML 代码
select:after { content:”.”; display:block; height:0; clear:both; visibility:hidden; }
|
请发表评论