HTML整站结构设计

最近在做整站方面的优化,所以借此机会把一些经验思想记录汇总成文,总览如下图:

整体结构

整体分为header,section-main和footer三大核心,而section-feature和section-postscript则根据需要增删。最外层为全屏背景的承载,中间的inner-center为居中内容

header.header>.inner-center
section.section-feature>.inner-center // if
section.section-main>.inner-center
section.section-postscript>.inner-center // if
footer.footer>.inner-center

如主体内容为多个全屏交替,则使用多个section-name布局,如首页:

header.header>.inner-center
section.section-feature>.inner-center
section.section-name-1>.inner-center
section.section-name-2>.inner-center
...
section.section-name-n>.inner-center
footer.footer>.inner-center

inner-center的居中css代码为:

.inner-center{
    margin-left: auto;
    margin-right: auto;
    width: 1200px;
}

section-main

由于主体内容一般都在这个区域,所以下面详细介绍下该区域的布局

无边栏设计

section.section-main>.inner-center

左边栏设计

section.section-main>.inner-center
    aside.aside-left
    main.main>.content

右边栏设计

section.section-main>.inner-center
    main.main>.content
    aside.aside-right

双边栏设计

section.section-main>.inner-center
    aside.aside-left
    main.main>.content
    aside.aside-right

可以看到当有边栏的时候,main里面嵌套了一层content,这层我们是用来使用负magin布局设计的,以方便使用响应式(转下面响应式设计)。

除此之外,为了全站方便控制各种布局,我们需要在body上增加一个class(主要是控制main),如:

// l表示layout
body.l-aside-left // 左边栏布局
body.l-aside-right // 右边栏布局
body.l-media // 响应式布局
body.l-min // 最小宽度布局

响应式设计

以右边栏响应式为例,兼容pc和pad,结构如下:

body.l-media.l-aside-right
  header.header>.inner-center
  section.section-main>.inner-center
      main.main>.content
      aside.aside-right
  footer.footer>.inner-center

基础css如下:

.aside-right,
.main{
    float: left;
}
.main{
    width: 100%;
}
 .aside-right{
    width: 300px;
    margin-left: -300px;
}
.l-aside-right .content{
    margin-right: 320px;
}

百分比设计

这种类型适合博客或各种文字流网站。这里我们实现最小宽度为980px,最大宽度为1200px,默认的右边栏宽度为300px,如果视窗小于或等于1024px的时候右边栏宽度为240px,css如下:

.inner-center{
    min-width: 980px;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

@media only screen and (max-width: 1024px){
   .aside-right{
      width: 240px;
      margin-left: -240px;
  }
  .l-aside-right .content{
      margin-right: 260px;
  }    
}

固定宽度设计

适合图片,视频等内容比较丰富的站点。同样我们要得到两个宽度,一个为980px,一个为1200px。css如下:

.inner-center{
       width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

@media only screen and (max-width: 1999px){
   .inner-center{
           width: 980px;
   }
   .aside-right{
      width: 240px;
      margin-left: -240px;
  }
  .l-aside-right .content{
      margin-right: 260px;
  }    
}

固定宽度设计

对于整站来说,并不是所有的页面都需要响应式设计思想,有些页面如果本身内容就比较少,这样做成一个比较小的固定的宽度980px,pad上也可以浏览

.l-min .inner-center{
    width: 980px;
    margin-left: auto;
    margin-right: auto;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Windows Community

Windows 8.1 应用再出发 - 视图状态的更新

本篇我们来了解一下Windows 8.1 给应用的视图状态带来了哪些变化,以及我们怎么利用这些变化作出更好的界面视图。 首先我们来简单回顾一下Windows 8...

2596
来自专栏达摩兵的技术空间

css实现文本超出显示…

文字内容过多,超出盒子模型的内容显示为省略号。提示:无论是单行还是多行文本,都需要设置高度,行高,超出不可见。(仅供参考)

733
来自专栏web前端教室

9.6,*少芳-学习笔记【web前端零基础课】

在学习一些js内容后,完成了一部分网站首页的动作设置(搜索栏、侧边栏、轮播图),对js代码进行了封装,重新整理了js文件。(index.js\ma...

1037
来自专栏云端架构

【云端架构】前端CSS实现单行、多行文本溢出显示省略号

如何实现单行文本的溢出显示省略号,同学们应该都知道用text-overflow:ellipsis属性来,当然还需要加宽度width属来兼容部分浏览。

3585
来自专栏mathor

枚举+优化(8)——前缀和2

2235
来自专栏IMWeb前端团队

ES6学习之函数传参

本文作者:IMWeb Terrance 原文出处:IMWeb社区 未经同意,禁止转载 ECMAScript 6 (or ECMAScript 201...

20910
来自专栏LIN_ZONE

css 控制文字超出部分显示省略号

该文章转自:http://www.daqianduan.com/6179.html

812
来自专栏vue

vue.js之动画篇

1262
来自专栏SeanCheney的专栏

Scrapy的CrawlSpider用法

rules是一组Rule对象。每条Rule定义了抓取网页的方式。如果多条规则匹配到同一链接,根据定义规则的顺序,使用第一个链接。

603
来自专栏lhyt前端之路

一些冷门的js操作0.前言1.数组2.位操作符2.1字符串转数字2.2更多的操作3. 构造类

大家学习的时候,一开始小白,然后接触到进阶的东西的时候,发现一切得心应手,有的人可能开始说精通了。突然有一天,发现了一些基于很基础的东西的骚操作,就开始怀疑人生...

652

扫码关注云+社区