html5页面布局怎么做

作者&投稿:祗连 (若有异议请与网页底部的电邮联系)
~
引言
浏览器中渲染的网页由许多东西组成-logo、信息文本、图片、超链接、导航结构等等。
HTML5为网页提供了一系列允许你创建结构化布局的标签。这些元素通常被称为语义化标签,因为它们能够清楚地给开发者和浏览器传达它们的意义和目的。本文将讨论一些有助于网页布局的重要的HTML5标签。
HTML5新元素及其特性
HTML5的语义化标签以及属性,可以让开发者非常方便地实现清晰的web页面布局,加上CSS3的效果渲染,快速建立丰富灵活的web页面显得非常简单。
本次学习HTML5的新标签元素有:
<header>定义页面或区段的头部;
<footer>定义页面或区段的尾部;
<nav>定义页面或区段的导航区域;
<section>页面的逻辑区域或内容组合;
<article>定义正文或一篇完整的内容;
<aside>定义补充或相关内容;
学习这些标签最好的方法当然就是试着使用它们。虽然现在有很多现成的网页布局的模板可以方便的拿来用,但是对于初学者来说,自己实现简单的页面布局绝对是有必要的。
这里通过一个简单的页面布局的例子,来展示上述标签的使用方法。
示例:模仿博客首页布局
实现如图2-1的网页结构,这是一个非常典型的博客页面:头部、尾部、水平导航栏、侧边栏导航以及内容。
图2-1
在图2-1中已经看到,相应标签实现的区域用名称标注了出来,比如头部Header
在编写页面前,有必要说一下:页面元素由HTML5实现,而元素的显示效果是CSS3渲染的,CSS3的代码可以和HTML5的代码放在同一个文件,也可以是独立的文件,只要在HTML5文件里引用即可。建议最好各自是独立的文件,这样的好处有:
1)符合单一职责原则:HTML5页面就负责管理元素,而CSS3文件只负责对相应HTML5文件显示效果的渲染,相互独立,互不相交。
2)降低页面的复杂度,便于维护:试想,当页面的元素数量增到很多的时候,同时在一个页面里管理元素和元素的显示属性,可读性是该有多差,后期的维护会很蛋疼。
3)加快浏览器的加载速度:第2)点的另外一个好处,简单的页面自然加载更快。
当然,如果就是习惯HTML5+CSS3放在一个文件里,也未尝不可,这里也只是建议。
下面来具体实现图2-1。
分为两个部分:1)HTML5文件;2)CSS3文件
一.HTML5部分
1. HTML5的文档声明
新建index.html文件,如果用的网页编写工具已经支持HTML5文件类型,那么,应该生成如下的HTML5模板:

1 <!DOCTYPE html>
2 <html lang="en-US">
3 <head>
4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
5 <title>Layout TEST</title>
6 </head>
7 <body>
8 </body>
9 </html>如果网页编写工具暂时不支持HTML5也没关系,自己写这几行代码也很简单。
说明:第一行:<!DOCTYPE html>是HTML5对文档类型的简化,化繁为简;(文档类型的作用:验证器依据它来判断该采用何种规则去验证代码;强制浏览器以标准模式渲染页面)
2. 头部
<header>标签实现
<header id="page_header">
<h1>Header</h1>
</header>说明:1)header不能喝h1,h2,h3这些标题混为一谈。<header>可以包含从公司logo到搜索框在内的各式各样的内容。例子中只含有标题。
2)同一个页面可以包含多个<header>元素。每个独立的区块或文章都可以含有自己的<header>.所以示例中为<header>添加唯一标示id属性,便于CSS3中灵活的渲染。在CSS文件里会看到id标示的作用。
3. 尾部
<footer>标签实现
<footer id="page_footer">
<h2>Footer</h2>
</footer>说明:位置是页面或者区块的尾部,用法和<header>基本一样,也会包含其他元素,这里也指定了id.
4. 导航
<nav>标签实现
<nav>
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">One</a></li>
<li><a href="#">Two</a></li>
<li><a href="#">Three</a></li>
</ul>
</nav>说明:导航的重要性对于一个网页至关重要,快速方便的导航是留住访客所必须的。
1)可以被包含在<header>或<footer>或者其他区块中,一个页面可以有多个导航。
2)导航一般需要CSS来渲染,随后将会看到CSS的渲染。
5. 区块和文章
<section>和<article>标签实现
<section id="posts">
/*可以包含多个< article>*/
<article class="post">
/*article的内容*/
</article>
<article class="post">
/*article的内容*/
</article>
</section><section>元素将页面的内容合理归类,合理布局。
下面是<article>的一般内容
<article class="post">
<header>
<h2>Article Header</h2>
</header>
<p>Without you?I'd be a soul without a purpose.
</p>
<footer>
<h2>Article Footer</h2>
</footer>
</article>可以看到它可以包含很多元素。
6. 旁白和侧边栏
<aside>标签实现旁白,侧边栏则由<section>实现。
<aside>是为主内容添的附加信息,入引言,图片等
<aside>
<p>sth. in aside
</p>
</aside><aside>一般加在<article>中使用
<article class="post">
<header>
<h2>Article Header</h2>
</header>
<aside>
<p>sth. in aside
</p>
</aside>
<p>Without you?I'd be a soul without a purpose.
</p>
<footer>
<h2>Article Footer</h2>
</footer>
</article>侧边栏,不是旁白!看做是右面的一个区域,包含链接,用<section>和<nav>实现即可。
<section id="sidebar">
<nav>
<ul>
<li><a href="2012/04">April 2012</a></li>
<li><a href="2012/03">March 2012</a></li>
<li><a href="2012/02">February 2012</a></li>
<li><a href="2012/01">January 2012</a></li>
</ul>
</nav>
</section>到这里,每种标签的使用就是这样了,下面是HTML5的完整代码index.html文件
<!DOCTYPE html>
<html lang="en-US">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<link rel="stylesheet" href="style.css" type="text/css">
<title>Layout TEST</title>
</head>
<body>
<h2>body</h2>
<header id="page_header">
<h1>Header</h1>
<nav>
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">One</a></li>
<li><a href="#">Two</a></li>
<li><a href="#">Three</a></li>
</ul>
</nav>
</header>
<section id="posts">
<h2>Section</h2>
<article class="post">
<h2>article</h2>
<header>
<h2>Article Header</h2>
</header>
<aside>
<h2>Article Aside</h2>
</aside>
<p>Without you?I'd be a soul without a purpose.
</p>
<footer>
<h2>Article Footer</h2>
</footer>
</article>
<article class="post">
<h2>article</h2>
<header>
<h2>Article Header</h2>
</header>
<aside>
<h2>Article Aside</h2>
</aside>
<p>Without you?I'd be a soul without a purpose. </p>
<footer>
<h2>Article Footer</h2>
</footer>
</article>
</section>
<section id="sidebar">
<h2>Section</h2>
<header>
<h2>Sidebar Header</h2>
</header>
<nav>
<h3></h3>
<ul>
<li><a href="2012/04">April 2012</a></li>
<li><a href="2012/03">March 2012</a></li>
<li><a href="2012/02">February 2012</a></li>
<li><a href="2012/01">January 2012</a></li>
</ul>
</nav>
</section>
<footer id="page_footer">
<h2>Footer</h2>
</footer>
</body>
</html>
二.CSS3部分
对于CSS文件,最好能够根据HTML文件的树结构,对应到相应的元素,有组织有层次的进行元素属性的渲染。这样既能够不遗漏元素,又便于查找修改。当然根据个人的习惯来定就好。
CSS3的属性定义更加丰富,这里不再赘述,网上有CSS3参考手册,用的时候查一查就好。更或者,连查都懒得查,还有专门的CSS3控件代码生成工具和网站,例如http://css-tricks.com/examples/,丰富的控件效果示例可以下载。还可以搜一些类似的。
这里直接贴出CSS3代码 style.css文件
@charset "utf-8";
/* CSS Document */
body { /*整个页面的属性设定*/
background-color: #CCCCCC; /*背景色*/
font-family: Geneva, sans-serif; /*可用字体*/
margin: 10px auto; /*页边空白*/
max-width: 800px;
border: solid; /*边缘立体*/
border-color: #FFFFFF; /*边缘颜色*/
}
h2 { /*设定整个body内的h2的共同属性*/
text-align: center; /*文本居中*/
}
header { /*整个body页面的header适用*/
background-color: #F47D31;
color: #FFFFFF;
text-align: center;
}
article { /*整个body页面的article适用*/
background-color: #eee;
}
p { /*整个body页面的p适用*/
color: #F36;
}
nav,article,aside { /*共同属性*/
margin: 10px;
padding: 10px;
display: block;
}
header#page_header nav { /*header#page_header nav的属性*/
list-style: none;
margin: 0;
padding: 0;
}
header#page_header nav ul li { /*header#page_header nav ul li属性*/
padding: 0;
margin: 0 20px 0 0;
display: inline;
}
section#posts { /*#posts 的section属性*/
display: block;
float: left;
width: 70%;
height: auto;
background-color: #F69;
}
section#posts article footer { /*section#posts article footer属性*/
background-color: #039;
clear: both;
height: 50px;
display: block;
color: #FFFFFF;
text-align: center;
padding: 15px;
}
section#posts aside { /*section#posts aside属性*/
background-color: #069;
display: block;
float: right;
width: 35%;
margin-left: 5%;
font-size: 20px;
line-height: 40px;
}
section#sidebar { /*section#sidebar属性*/
background-color: #eee;
display: block;
float: right;
width: 25%;
height: auto;
background-color: #699;
margin-right: 15px;
}
footer#page_footer { /*footer#page_footer属性*/
display: block;
clear: both;
width: 100%;
margin-top: 15px;
display: block;
color: #FFFFFF;
text-align: center;
background-color: #06C;
}相信无需多解释,一看就能明白。
想要让页面的显示更精美绚丽,CSS3好好看看吧。
目前来看,HTML5的简单但强大,CSS3的丰富,二者结合能做出怎样的惊人的效果真的很令人期待。


哪款浏览器对html5,css3支持最好
也就不会有无谓的http请求了。下面这段代码仅会在IE浏览器下运行:<!--[if IE]> <![endif]--> 当然如果你不喜欢调用外网文件,你也可以下载下来上传到自己的服务器单独调用(作者允许)。

svg画线-如何用svg来画出div的两条对角线,如果用css也可以吗?_百度知 ...
<!DOCTYPE_tml> -_TML5_utorials HTML5_VG_ine_xample <svg_d="svgLineTutorial"_tyle="border-style:solid;border-width:2px;"_eight="200px"_idth="200px"_mlns=""> _<!--<line_1="0"_1="0"_2="50"_2="200"_tyle="stroke:rgb(100,100,0);stroke-width:5"\/>--...

web前端培训要多久?
1、【web前端】其实是很适合零基础人员学习的,整体来说的话也不算特别难,那我们在学习的过程中,第v一阶段肯定是html+css,那么这个部分从入门到高级的话,学习起来都不是问题。2、第二阶段可以是css3+html5,那么这个环节学到位了,再加上前面的布局,基本上一个人是可以单独的开发一个大型的...

前端培训那个机构好一点?
感兴趣的话点击此处,免费学习一下前端就是利用三大核心(html,css,JavaScript分别是网页控件、美化控件代码、增强表现力的脚本语言)技术,以及衍生技术开发出来的主要在浏览器上展示的页面,其成品可以为:任何浏览器上看到的任何页面、官方网站、后台管理系统、微信小程序、公众号、TML5 开发移动端 APP、...

php到什么程度可以找工作?
php工作要求:精通php,html5,jquery;熟悉MYSQL等数据库;具备网站系统分析架构与设计经验;对业务有很强的领悟能力,能快速准确的将业务需求转化为业务架构,具备创新精神 ;能够承受工作压力,具有良好地沟通交流和团队合作能力;熟练运用MVC架构,百度地图或GoogleMap等相关开发经验者优先;熟悉TML5、CSS...

制作美甲美睫海报用什么小程序?可以做海报的手机软件
5、AdobeDreamweaver DW是集网页制作和管理网站于一身的所见即所得网页代码编辑器。利用对_TML、CSS、JavaScript等内容的支持,设计师和程序员可以在几乎任何地方快速制作和进行网站建设。AdobeDreamweaver使用所见即所得的接口,亦有HTML(标准通用标记语言下的一个应用)编辑的功能,借助经过简化的智能编码...

吉隆县19678521213: 页面布局html5精确定位 -
董顷达诺: 很简单` `在画了方框后 L 命令 上 多少 下多少 输进去 回车 就上去了 而后直接画就是了 最后 提醒 多余的可以删除 鄙人 刚用时犯的错```(呵呵``)

吉隆县19678521213: html5怎么分格局,三层 -
董顷达诺: 可以通过DIV来分块布局,然后通过CSS样式来调整大小,颜色等样式.参考代码如下:<!DOCTYPE html><html><head><style>#header { background-color:black; color:white; text-align:center; padding:5px; }#nav { line-height:30px; background-...

吉隆县19678521213: 用html5怎么做出这种页面 -
董顷达诺: 1、按照正常的思路,布局就是div布局,写一个固定下来,作为模板,在每次获取数据的时候使用功能代码绑定数据到布局上面,自动生成页面内容就可以了.拆分出单个模板来,很明显每项都是一样的 就这个样式写div+css不会吗?两层div 的嵌套,里面布局排文本标签,image标签就可以了,绑定id填数据,或者遍历填数据.简单布局是一种,再就是<ul><li><li></ul>这种

吉隆县19678521213: 这种HTML5布局是什么意思? -
董顷达诺: 这个就是简单的html布局,里面有html 标签组成,你可以标签里面添加内容然后用浏览器打开,就能看到渲染的html 页面了.

吉隆县19678521213: 如何用css进行网页布局 -
董顷达诺: 实现网页布局的方式方法比较多,布局方式可以大概分为这几类.布局种类:1、table布局(网页的兴起,1995)2、Flash布局(自由的黄金时代,1996)3、div+css(CSS的诞生,1998)4、栅格与响应式(移动端的兴起,2007与2010) 当前...

吉隆县19678521213: html5+css页面怎么布局 -
董顷达诺: HTML写出框架之后CSS里面定义样式布局

吉隆县19678521213: 用html5如何将平面布局分为四部分 -
董顷达诺: 横向4个盒子浮动好,给width:25%; 就是平均4部分, 不平均的话就自己调百分比

吉隆县19678521213: html5如何最圆形布局 -
董顷达诺: 你是指生成圆角或者圆吗?一般都是用:border-radius属性.如果是其他问题,欢迎补充!

吉隆县19678521213: HTML5如何利用rem实现自适应布局 -
董顷达诺: 1. 分析设计图 假设设计图大小为1080px.这也就意味着,在开发时,需要兼容的最大分辨率为1080px,最小的为320px.2. 调整视口 代码实例:布局之路-移动端开发实例 代码解析:由于使用不同设备打开网页时,宽度均有所不同,所以不...

吉隆县19678521213: 如何去设计一个自适应的网页设计或html5 -
董顷达诺: 如今移动互联网随着3G的普及,越来越火爆,更多需求跟随而来!APP应用市场和APP应用数量成倍成倍的增长!从而给移动互联网带来新的挑战!移动设备正超过桌面设备,成为访问互联网的最常见终端.于是,网页设计师不得不面对一个...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网