PageLayoutBasedonCSS+Div,Computer

怎么做 5
ScienceandApplication计算机科学与应用,2020,10
(2),303-311PublishedOnlineFebruary2020inHans./journal/csa/10.12677/csa.2020.102031 AnalysisofFixedandVariableWidthWebPageLayoutBasedonCSS+Div KuiGao,XiaocuiFu,WeiyanLiSchoolofInformationScienceandEngineering,ShandongAgriculturalUniversity,TaianShandong Received:Feb.1st,2020;epted:Feb.14th,2020;published:Feb.21st,2020 Abstract CSS+Divismonlyusedtechnologytorealizepagelayoutincurrentwebpagedesign,whichcanrealizefewerpagecodes,fasterreadingspeed,easierupdatingandricherpagelayouteffect.Bywayofexample,thispapergivestheusemethodandprecautionsofusingCSS+DivtechnologytorealizethefixedwidthandvariablewidthwebpagelayoutthroughthenumericalsettingofDivlabelwidth,equalproportionsetting,absolutepositioningmethodandimprovedfloatingmethodsetting,soastoachievethepurposeofmastering. Keywords CSS,Div,FixedWidthLayout,VariableWidthLayout,EqualRatio,ImprovedFloatingMethod 基于CSS+Div的固定宽度与变宽度网页布局剖析 高葵,付晓翠,李蔚妍山东农业大学信息科学与工程学院,山东泰安 收稿日期:2020年2月1日;录用日期:2020年2月14日;发布日期:2020年2月21日 摘要 CSS+Div是当前网页设计中实现页面布局的常用技术,可以实现页面代码更少,读取速度更快,更新更容易,页面布局效果更丰富。
本文通过举例,给出使用CSS+Div技术,通过Div标签宽度的数值设置,等比例设置,绝对定位法和改进浮动法设置实现固定宽度和变宽度网页布局的使用方法和注意事项,到 文章引用:高葵,付晓翠,李蔚妍.基于CSS+Div的固定宽度与变宽度网页布局剖析[J].计算机科学与应用,2020,10
(2):303-311.DOI:10.12677/csa.2020.102031 高葵等 达掌握的目的。
关键词 CSS,Div,固定宽度布局,变宽度布局,等比例,改进浮动法 Copyright©2020byauthor(s)andHansPublishersInc.ThisworkislicensedundertheCreativeCommonsAttributionInternationalLicense(CCBY4.0)./licenses/by/4.0/ Openess
1.引言 基于CSS+Div的排版是当前网页设计中实现页面布局的常用技术。
它使用
标记将页面进行分区域,然后对各个区域进行CSS属性设置,最后再在各个区域中添加相应的内容。
利用CSS+Div排版的页面读取速度更快,更新更容易,页面布局效果更丰富。
CSS常用布局样式分为固定宽度布局和变宽度布局[1]。
固定宽度布局,在浏览器窗口大小变化的情况下,页面显示效果保持原样,不会变化,缺点是在浏览器窗口大小变化情况下,网页内容显示效果不全面。
变宽度布局,可以使内容的整体宽度随浏览器窗口宽度的变化而变化,浏览器窗口大小变化情况下,网页内容显示效果全面,变宽度布局更加灵活,实用性更强。

2.使用举例2.1.固定宽度布局 一般情况下,此类页面布局的列都有固定的宽度,在这里以经典的三行两列宽度固定布局为例讲解固定分栏布局。
例题1:完成页面,效果如下图
1。
Figure1.Weblayout1图
1.网页布局
1 对应的主要代码如下:doctypehtml> DOI:10.12677/csa.2020.102031 304 计算机科学与应用 高葵等 固定宽度布局 #container{ /*页面顶部容器的CSS规则*/ width:900px; /*设置元素宽度*/ margin:0auto; /*设置元素自动居中对齐*/ } #header{ background-color:#0F0;/*设置背景色*/ height:30px; /*设置元素高度*/ } #mainbox{ background-color:#cff;/*设置背景色*/ width:600px;/*设置元素宽度*/ height:300px;/*设置元素高度*/ float:left;/*设置左浮动*/ } #sidebox{ width:300px;/*设置元素宽度*/ background-color:#ff0;/*设置背景色*/ float:right;/*设置右浮动*/ } #footer{ background-color:#f0f; height:30px; clear:both;/*清除浮动效果*/ } ……
……
……
……
分析:可以看到这是一个三行两列宽度固定布局。
所有div元素宽度固定,页面显示效果固定不变, 不会随着浏览器窗口大小变化而变化。
DOI:10.12677/csa.2020.102031 305 计算机科学与应用 高葵等如上例,在浏览器窗口变小的情况下,显示如下图2所示,内容不能完整显示。
Figure2.Weblayout2图
2.网页布局
2 使用固定宽度布局实现的页面布局,在浏览器窗口大小变化的情况下,不能看到页面的完整结构[2],而使用变宽度布局方式可以弥补这个缺陷。
2.2.变宽度布局 变宽度布局,可以使内容的整体宽度随浏览器窗口宽度的变化而同步变化[3]。
宽度变化有两种不同的情况,这里以两列为例。
一种情况是两列按照一定比例同时变化的,另一种情况是一列固定,另一列变化宽度。
1)等比例变宽布局等比例变宽布局是各个Div区域的宽度会等比例适应浏览器窗口。
例题2:完成页面,效果如下图
3,图4所示。
图3是大浏览器窗口下显示效果,图4是小浏览器窗口下显示效果。
在例题1的基础上,修改代码如下: Figure3.Weblayout3图
3.网页布局
3 DOI:10.12677/csa.2020.102031 306 计算机科学与应用 高葵等 Figure4.Weblayout4图
4.网页布局
4 #container{width:80%;/*删除固定宽度,改为比例宽度*/margin:0auto; }#header{ ……/*与前面相同*/}#mainbox{ float:left;width:66.9%;/*删除固定宽度,改为比例宽度*/background-color:#0FF;}#sidebox{float:right;width:33%;/*删除固定宽度,改为比例宽度*/background-color:#FF0;}#footer{……/*与前面相同*/}……/*其余部分与上一例题相同*/分析:在这个页面中,以比例宽度代替固定宽度,实现页面随浏览器窗口大小等比例变化。
网页内容的宽度为浏览器窗口宽度的80%,页面中左侧和右侧的宽度保持在2:1的比例,可以看到无论浏览器窗口如何变化,它们都会等比例变化[4],如上图3是大浏览器窗口下显示效果,上图4是小浏览器窗口下显示效果。
2)单列变宽布局 DOI:10.12677/csa.2020.102031 307 计算机科学与应用 高葵等单列变宽布局是指单列宽度变化,而其他列保持不变,可以使用绝对定位法和改进浮动法实现[5]。
例题3:使用绝对定位法完成单列变宽布局页面[6],结果如下图
5,图6所示。
Figure5.Weblayout5图
5.网页布局
5 Figure6.Weblayout6图
6.网页布局
6 在上例的基础上,修改代码如下: #container{ width:80%;/*设置总宽度80%,这样总宽度会随浏览器窗口变化*/ margin:0auto; position:relative;/*设置为相对定位属性,使它成为其里面列的定位基准*/ } #mainbox{ /*删除宽度设置*/ float:left; background-color:#0FF; margin-right:300px;/*设置右外边距,使它不会与sidebox列重叠*/ } #sidebox{ position:absolute;/*设置为绝对定位属性*/ DOI:10.12677/csa.2020.102031 308 计算机科学与应用 高葵等 top:30px;/*设置其紧贴container的上部*/right:0;/*设置其紧贴container的右侧*/width:300px;/*设置宽度为固定值*/background-color:#FF0;}分析:在这个页面中,实现了右侧列单列宽度固定,而左侧列变化宽度的布局样式。
可以看到上图5是大浏览器窗口下显示效果,上图6是小浏览器窗口下显示效果,右侧列宽度不变,左侧列随浏览器窗口大小而变化。
这种方式有种缺陷,当固定宽度列的高度大于活动列的高度时,会使固定宽度列与页脚部分重叠[7]。
如下图7所示。
Figure7.Weblayout7图
7.网页布局
7 解决方法是设置变宽度列的高度是最高的,就不会出现重叠现象。
如上例题,将mainboxde的高度属性设置的足够大,就不会出现内容重叠了。
效果如下图8所示。
以上页面的功能也可以使用改进浮动法实现,核心问题是实现变宽度列mainbox的宽度等于“100%固定宽度列sidebox宽度”。
例题4:使用改进浮动法完成单列变宽布局页面[8],效果如图
5,图6所示。
主要代码如下:#container{ width:85%;margin:0auto; }#header{……/*与前面相同*/}#contentwrap DOI:10.12677/csa.2020.102031 309 计算机科学与应用 高葵等 Figure8.Weblayout8图
8.网页布局
8 { float:left; /*设置为左浮动*/ margin-right:-300px;/*设置右外边距为负值,即向左平移300px*/ width:100%; /*设置为100%宽度*/ } #mainbox{ float:left; background-color:#0FF; margin-right:300px;/*设置右外边距,使它不会与sidebox列重叠*/ } #sidebox{ float:right;/*设置为右浮动*/ width:300px; background-color:#FF0; } #footer{ background-color:#f0f; height:30px; clear:both;/*清除浮动效果*/ } DOI:10.12677/csa.2020.102031 310 计算机科学与应用 高葵等 ……
………………/div>分析:通过在可变宽度列mainbox的外面又套了一层Div,即conternwrap标签,设置宽度为100%,设置margin-right的值为负的固定宽度列sidebox宽度数值,同时再将变宽度列mainbox的margin-right的值的设置为正的固定宽度列sidebox宽度数值,实现了mainbox列的“100%-固定宽度列sidebox宽度数值”的宽度。
最大好处是可以不用考虑各列的高度,通过footer的clear属性设置,保证了不会发生重叠现象[9]。

3.总结 通过以上的例题和分析可以得出如下结论:固定宽度页面布局需要指定列的宽度,变宽度页面布局可以根据需要设置列的宽度比例,采用绝对定位法或改进浮动法来实现[10]。

4.结束语 本文对固定宽度页面布局和变宽度页面布局进行了举例和分析,深入剖析了使用CSS+Div如何固定宽度和变宽度,通过设置Div的宽度,采用数值单位设置可以实现固定宽度布局,采用等比例单位设置,绝对定位法或改进浮动法设置可以实现变宽度布局设置,在实际应用中,根据设计需求,采用不同的布局模式,设计出符合要求的页面布局,进而达到熟练掌握的目的。
参考文献 [1]Freeman,
A.HTML5权威指南[M].北京:人民邮电出版社,2014:188-195.[2]李东博.HTML5+CSS3从入门到精通[M].北京:清华大学出版社,2018:112-115.[3]郑阳平.网页设计与制作实用教程[M].北京:清华大学出版社,2016:158-165.[4]王海波.网页设计与制作——基于计算思维[M].北京:机械工业出版社,2014:101-105.[5]李毅.网页制作与开发教程[M].北京:人民邮电出版社,2015:193-196.[6]黑马程序员.网页设计与制作HTML5+CSS3+JavaScript[M].北京:中国铁道出版社,2019:182-185.[7]张树明.WEB前端设计基础[M].北京:清华大学出版社,2018:80-100.[8]徐洪峰.HTML+DIV+CSS[M].北京:清华大学出版社,2017:292-295.[9]常新峰,王金柱.网页设计实战[M].北京:清华大学出版社,2017:247-255.[10]传智播客高教产品研发部.网站设计基础教程[M].北京:人民邮电出版社,2016:180-198. DOI:10.12677/csa.2020.102031 311 计算机科学与应用

标签: #文件 #尺寸 #文件 #打不开 #文件 #文件 #文件 #文件

本站数据均来自互联网网友分享,若本页侵犯到您的权益请告知我们(jinmi8@foxmail.com),我们将在48小时内处理。Copyright © apjn.cn