在cnblogs,一直都是使用官方自带的那些模板,而且感觉也一直很良好!不过最近用手机搜索一些相关的技术资料,很多都来自cnblogs,有些博主的页面在和机端显得很好,有些则展示得不那么友好了……忽然想起了cnblogs可以完全自定义CSS,早上起来就开始整了。由于我一直都喜欢干净整洁且清晰的页面,能不用图就不用。这次干脆偷了个懒,一张图都没用上……

先把最终效果截出来:

情况一:屏幕宽度大于960px时,左侧自动伸缩,右侧固定320px

情况二:屏幕大于在768px,小于960px时,右侧缩小100px(即220px)

情况三:屏幕大于640px,小于768px时,整个页面变为一栏,但左文章列表中的日期与文章仍然呈左右显示。

情况四:当屏幕小640时,当做手机端处理

------------------------- 我是一条分隔线 ------------------------

开始工作:

第一步:了解cnblogs首页的结构

只有把DOM结构弄清楚了,才能有针对性的实施方案,下面是cnblogs首页的基本结构

 <body>
<div id="home">
<!--页头-->
<div id="header"></div> <!--主体-->
<div id="main">
<!--主栏-->
<div id="mainContent">
<div class="forFlow">
</div>
</div> <!--侧边栏-->
<div id="sideBar"></div>
</div> <!--页尾-->
<div id="footer"></div>
</div>
</body>

结构还是麻清晰的,下面简单说一下:整个页面由id="home"的div包含起来。然后里面分别包括:

1、页头:id="header"

2、主本:id="main"

3、页尾:id="footer"

这时注意:main包括了mainContent和sideBar两个部分,上面我将它称为主栏和侧边栏,而主栏又包含了一个forFlow。这种结构看似多了很多层,但其实这样的结构能适用于多种不同的布局的实现,具体不详细解说了。

把结构搞清楚了,就可以开始实现页面的整体框架了,接着看。

第二步:header的实现

这个部分很简单,不设置宽度即可,这样就能适用各种不同的屏幕了。连媒体查询部分的CSS都不用(当然这也是我的要求简单的原因),下面是CSS

#header {
margin-bottom:20px;
overflow:hidden;
background:#000;
position:relative;
}

由于本篇只讲如何实现这个大框架,具体header内部的细节就不解说了。

第三步:实现footer

这个部分与header的实现没多大区别,请直接看CSS

#footer {
padding:30px 0;
text-align:center;
font-size:16px;
border-top:solid 1px #ddd;
margin-top:20px;
margin-bottom:10px;
}

第四步:main的实现(重点)

1、先实现左右布局

左右布局一般都是用float:left和float:right来实现。但是这种不符合我的需求,因为我的右侧是固定大小的,但左侧是自动伸缩的。关键问题是:如何让左侧自动伸缩呢?默认情况下,div是自动继承父层的宽度的。试想:如果一个div Father的子div Son的有一个margin-right:320px属性会怎样呢?(没错,不管怎样,大div的右侧总会空出320px的宽度来)。好了,到这里右侧的320px已经空出来了。根据cnblogs首页结构,我们可以定义出这样一个CSS来:

#mainContent {
width: 100%;
font-size: 14px;
}
#mainContent .forFlow {
margin-right: 350px;
}

这里#mainContent相当于div Father, #mainContent .forFlow相当于 div Son。接下的问题是:main的空间都被#mainContent给占完了,即使.forFlow把右侧空出320px来,也轮不到sideBar来占位,事实也是如此!那么解决的办法是:

让#mainContent浮动起来,让sideBar也浮动起来(并且给一个margin-left:-320px,这样会使sideBar会抢位到上面去与mainContent并排,这就是神奇的地方),最终代码如下:

#main { margin-left:10px; margin-right:10px; }
#mainContent {
width: 100%;
float: left;

font-size: 14px;
}
#mainContent .forFlow {
margin-right: 350px; //这里留出350px是为了和右边保持距离
}
#sideBar {
float: left;
width: 320px;
margin-left: -320px;

font-size: 14px;
}

2、实现屏幕在960px以下的布局:只改变右侧sideBar的宽度,同时.forFlow的右侧亦要留出足够的空间来,以免内容重合。

@media (max-width: 960px) {  #mainContent .forFlow {
margin-right: 250px;
}
#sideBar {
width: 220px;
margin-left: -220px;
}
}

3、实现屏幕在768px以下的布局:768px下已经只分一栏了,所以不需要再浮动(注意float:none),同时它们的宽度都充满了父容器。

@media (max-width: 768px) {
#mainContent {
width: 100%;
float: none!important; //这是加important是为了覆盖cnblogs系统的768px像素的媒体查询
}
#mainContent .forFlow {
margin-right:;
}
#sideBar {
float: none;
width: 100%;
margin-left:;
}
}

至此,基本上的布局就已经实现了,至于其它一些细节上的实现,请根据喜好自拟!其实本文的重点是:两栏情况下,一栏固定宽度,另一栏自动伸缩是如何实现的?

为了各位一方便查看效果,可以扫描下面的二维码访问我的博客首页:

扫描二维码访问我的cnblogs博客主页

给我的cnblogs主页做一个响应式布局模板的更多相关文章

  1. 使用bootstrap做一个响应式的页面

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. SharePoint 2013 的HTML5特性之响应式布局

    今天偶然看到一本书<Pro SharePoint 2013 Branding and Responsive Web Development>,看到SharePoint 2013基于HTML ...

  3. SharePoint 2013的HTML5特性之响应式布局

    今天偶然看到一本书<Pro SharePoint 2013 Branding and Responsive Web Development>,看到SharePoint 2013基于HTML ...

  4. css 响应式布局

    移动端最让人闹心的就是在不同的手机要做错响应式布局适应各种手机,开始自己做这方面走了很多的弯路,响应式布局如果是部件,就按实际的大小单位px等设置,像宽可以按照百分比计算,长的可以百分比.auto 或 ...

  5. Bootstrap4响应式布局之栅格系统

    前面说了Bootstrap4的下载和简单使用,现在我们接着往下学习,Bootstrap4的响应式布局主要依靠栅格系统来实现的.面老K先来讲解一下Bootstrap4的栅格系统,让你能够更快的了解Boo ...

  6. Power Apps 创建响应式布局

    前言 我们都知道Power Apps作为低代码平台,最大的优势就是各个设备之间的兼容性,尤其是自带的响应式布局,非常好用. 这不,我们就为大家分享一下,如何使用Power Apps画布应用,创建响应式 ...

  7. 超 Nice 的表格响应式布局小技巧

    今天,遇到了一个很有意思的问题,一名群友问我,仅仅使用 CSS,能否实现这样一种响应式的布局效果: 简单解析一下效果: 在屏幕视口较为宽时,表现为一个整体 Table 的样式 而当屏幕视口宽度较小时, ...

  8. 响应式布局中的CSS相对量

    一个响应式布局,要能够根据设备屏幕尺寸的改变,动态的调整页面内容,展现不同的设计风格. 在进行响应式的 CSS 代码编写过程中,经常会用到一些相对尺寸,以达到相对定位的目的.例如,常见的响应式布局中需 ...

  9. IT兄弟连 HTML5教程 响应式布局实例

    在学习Media Queries模块前,先通过一个响应式布局实例来了解一下响应式布局和Media Queries模块的简单应用.在本例中,使用HTML5的结构元素定义了5个盒子.当浏览器窗口尺寸不同时 ...

随机推荐

  1. 基于MAC10.12+MYSQL5.7.17搭建XMPP服务器【黑苹果系统】

    在以前的公司中了解到XMPP可以搭建即时通讯APP.出于好奇自己在空余时间也学了一下搭建XMPP服务器,其中遇到了许多问题,经过坎坷的路程终于搭建成功[这些坎坷的经历主要是由于自己的无知造成的] 下面 ...

  2. sass、less、stylus的安装及使用

    一.什么是CSS预处器 CSS预处理器定义了一种新的语言,其基本思想是,用一种专门的编程语言,为CSS增加了一些编程的特性,将CSS作为目标生成文件,然后开发者就 只要使用这种语言进行编码工作.通俗的 ...

  3. Vue开源项目库汇总

    最近做了一个Vue开源项目库汇总,里面集合了OpenDigg 上的优质的Vue开源项目库,方便移动开发人员便捷的找到自己需要的项目工具等,感兴趣的可以到GitHub上给个star. UI组件 elem ...

  4. 基于 Koa平台Node.js开发的KoaHub.js的跳过组件代码

    koahub-skip koahub skip middleware koahub skip Conditionally skip a middleware when a condition is m ...

  5. 1578: [Usaco2009 Feb]Stock Market 股票市场

    1578: [Usaco2009 Feb]Stock Market 股票市场 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 414  Solved: 1 ...

  6. 2659: [Beijing wc2012]算不出的算式

    2659: [Beijing wc2012]算不出的算式 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 757  Solved: 425[Submit] ...

  7. 【HLA】初识HLA/RTI

    本文主要对近期所翻阅的一些论文及资料进行的概要性整理,后续会有更多的关于HLA的研究细节发布,基于博客园的知识共享平台,以期共同进步! 一.引言 仿真的历史由来已久,在系统研制过程中,基于建模及仿真技 ...

  8. markown编辑器截图粘贴预览,并将图片传至七牛云

    最近在做一个项目,需要实现类似QQ截图后,就是能够在富文本编辑器中粘贴截图并预览. 先看一下效果: 分析一下实现步骤: QQ截图后在编辑器中粘贴,肯定会有一个粘贴事件,即 paste 事件 在事件回调 ...

  9. Weexpack 使用教程

    简介 weexpack 是 weex 新一代的工程开发套件,是基于weex快速搭建应用原型的利器.它能够帮助开发者通过命令行创建weex工程,添加相应平台的weex app模版,并基于模版从本地.Gi ...

  10. Spring Data操作Redis详解

    Spring Data操作Redis详解 Redis是一种NOSQL数据库,Key-Value形式对数据进行存储,其中数据可以以内存形式存在,也可以持久化到文件系统.Spring data对Redis ...