跳至侧栏

自定义博客园皮肤:暗色流体响应式布局

     博客园的皮肤模板虽然有100多套,但我需要的作品却没几套,从布局上看,大多是固定布局,有的使用表格布局,有的将侧边栏在HTML页面的代码顺序放在主内容的前面。这些布局方式不利于页面缩放和不同屏幕尺寸与分辨率的设备浏览,尤其是在当今网页浏览设备屏幕尺寸与分辨率多样化的时代,流体与响应式布局才是最佳的选择。从配色上看,博客园有3款还不错的暗色皮肤,但不符合我布局的要求。
     我想要自己的博客皮肤满足以下要求:
模版选择:不能使用表格布局,侧边栏在HTML页面的代码顺序放在主内容
               的后面,页面结构和样式简洁。有利于自定义CSS样式。
配色:主背景配色为暗色,文本等颜色为亮色。
布局:水平居中,侧边栏在左边的两列布局,流体+响应式布局。
    下面就按照这三个方面的要求来自定义博客皮肤。

 

1.选择一套已有的博客模版
 

     博客园的人民不能够自己自由地设计博客的静态HTML页面,除非你的作品得到博客园的审核通过,然后作为共享模版供广大博客园人民选择使用。但博客园已有的100多套模版里,大多能满足静态HTML页面的选择要求。另外,博客园的模版都有既定的CSS样式,这一点也得考虑在内。综合考量,进入博客管理设置,这里选择一款叫做“LessIsMore”的模版。从下图可以看出,这个模版作为自定义样式的基础还是很不错的。

 

 

2.配色、字体、修饰和布局微调
 

     由于已经选好了一个有利于自定义样式的模版,再结合浏览器的开发者工具,自定义页面的配色总的来说还是比较容易的,但个别地方(如代码块内)的样式都是在HTML页面元素的style属性里定义的,没有类和ID属性,由JavaScript自动生成,自定义样式很困难,只能在不影响可访问性的情况下,退而求其次。另外,我对有的地方字体、字体大小、背景颜色做了调整,有的地方添加了边框和阴影效果,有的地方进行了 margin、padding 的微调。下面是具体的CSS代码:

/*------CSS Code-----------------------------------*/
#navigator { background#666; }
#navList { font-size16px; }
.blogStats { font-size12px; }
#sideBar { width20%bordernonepadding0; }
    #sideBar h3 { padding-left8pxbackground-color#666; }
#sideBarMain { padding-left8px; }
body { background-color#333color#ffffont-size14px; }
h1h2h3h4h5h6th.feedbackCon.blogStats { color#fff; }
#main { border1px solid #e5e5e5; }
.day { margin20px 0px; }
.postTitle { padding-left20pxfont-size16px;
             border-bottom-color#666; }
.postBody.postCon { padding0px 20px 10px; 
                      border-bottom1px solid #666; }
.postDesc { padding-right20px; }
a.postCon a.postBody a.feedbackCon a { color#0dd; }
    a:hovera:activea:focus { color#ff8text-decorationnone; }
#navigator#MySignature.day.post { border1px solid #e5e5e5; 
    border-radius8pxbox-shadow2px 2px 10px #aaa; }
#navigator { border-radius8px 8px 0px 0px; }
.post { border-rightnoneborder-topnone; 
        border-radius0px 0px 8px 8pxpadding-top1px; }
.cnblogs_code.cnblogs_code div { 
    color#000font-familyconsolasmonospacesans-serif; }
 

3.布局

 

3.1 水平居中

 

     整体水平居中最常用的方法是,将body内要居中的所有内容放在一个容器元素中,这个容器作为body的子元素,然后对这个容器进行水平居中。在选择的“LessIsMore”模版中,id为home的div满足这个容器的要求。下面是水平居中的CSS代码:

body 
{ 
   /*其它主要浏览器不需要这个样式,
   但在IE6/7居中是必须的*/
   text-align:center; 
}
#home 
{ 
   /*margin: 0px auto;可以使内容在除IE6/7外的其它
   主要浏览器内居中*/
   margin0px auto; 
   /*因为body的text-align:center;样式具有继承性,
   所以要重置文本向左对齐*/
   text-align:left; 
   max-width:960px;
}
 

3.2 导航条的改进

 

     “LessIsMore”模版的导航条默认样式是,将导航条内的每一项li进行左浮动,名为.blogStats的div进行右浮动,显示设置导航条容器的div的高度来防止浮动造成的导航容器塌陷无高度。我觉得没必要将li都进行左浮动,只需将其display:inline即可,然后将ul与名为.blogStats的div分别进行左浮动和右浮动即可。最后,最好清除浮动,使作为导航容器的div可以包裹住里面的内容。CSS代码如下:

#navigator {  height:autooverflow:hidden*zoom:1;}
/*名为.blogStats的div在选择的模板中已经进行了右浮动
不必再进行设置*/
#navList { float:left; }
#navList li { displayinlinefloatnone; }

 

3.3 两列和流体布局
 

3.3.1 模版的默认实现

 

     我发现博客园的很多皮肤模板以及广大博客园人民使用或自定义的皮肤,要么主内容与侧边栏都是固定宽度,要么侧边栏固定宽度主内容自适应宽度。好像没有侧边栏与主内容都是非固定宽度的,这样很不利于页面缩放。

我的布局要求是,侧边栏在左,主内容在右,呈两列布局。当然,侧边栏在右边也是很不错的布局方式,但出于习惯等原因,我选择侧边栏在左。选择流体布局的原因是为了便于缩放。因为我实现两列布局的同时也实现了流体布局,所以将这两个方面放在一起说明。
实现多列布局方式有多种,“LessIsMore”模版已经是侧边栏在左的两列布局,使用浮动方式实现。浮动方式实现的多列布局具体到细节也有较多的不同方式。“LessIsMore”模版默认将主内容(id为mainContent)宽度设为100%向右浮动,侧边栏(id为sideBar)定宽220px向左浮动。然后,将主内容的左外边距(margin-left)设为一个足够的负值(-250px),将侧边栏“拉”到主内容内部的左边。但这样侧边栏会与主内容内部的内容重叠。所以,在主内容里又嵌套了一个类名为forFlow的div作为其它元素的容器,并将这个容器的margin-left设置为一个足够大的值以避免重叠。主要代码如下:
#mainContent { width100%margin-left-250pxfloatright; }
#sideBar { width220pxfloatleft; }
.forFlow { margin-left:266px; }
这样的两列布局实现是一种侧边栏宽度固定,主内容宽度自适应的设计。不利于缩放,而且实现得比较别扭。

 

3.3.2 流体布局的优点与不足
 

     流体布局的核心是采用百分比定义列的宽度,在使用浮动实现多列布局的情况下,每列都要以百分比定义宽度(或者部分列使用百分比为单位的水平外边距),只要所有列的总宽(这要考虑盒模型的总宽,而不仅仅是内容的宽度)不超过100%,页面放大的时候不会出现水平滚动条,这正是我需要的结果。

可是,流体布局也有其局限性:
其一,无法使某一列宽度自适应。但由于每列的百分比都是分配好的,这也就不是什么大问题了。
其二,若屏幕很宽,则列之间的间隙就会很大。这可以通过设定容器#home的最大宽度来解决这个问题。前面水平居中代码的最后一个样式max-width:960px;就是为了解决这个问题。可惜的是,在天朝占主流的 IE6 不支持 max-width 属性。但这并不是大问题,因为特别宽的屏幕并不多见,即便如此,宽屏上的字体等内容相对来说也是较宽较大的,比例上还算协调。
其三,若屏幕很窄,或者进行较大比例的缩放,每列就会很细长,也不利于阅读。屏幕宽度小的问题的解决的方法就是后面要说的“响应式布局”。大比例缩放问题目前我还真不知道有什么好的解决方法,还请知道的朋友多多指教!但鉴于进行大比例缩放的情况极少,所以这也不是什么大问题。下面就来实现两列的流体布局。

 

3.3.3 自定义实现
 

     啰嗦了这么多,其实实现的代码很少,如下:

#sideBar { width20%; }
#mainContent { margin-leftautowidth:78%; }
.forFlow { margin:auto; }
     首先,这是基于浮动的布局。由于“LessIsMore”模版的既有样式已经将#mainContent向右浮动(必须),将#sideBar向左浮动(非必须),所以,自定义样式就不必进行浮动样式的设置了。其次,边栏的宽度设为20%,主内容的宽度设为78%,这是必须的,两列之间留出2%的间隙。最后,要将#mainContent的左外边距-250px和.forFlow的所有外边距重置为auto。

 

4.响应式布局与CSS媒体查询
 

4.1 为什么要响应式布局和媒体查询

 

     为什么要响应式布局和媒体查询?因为自从智能手机和平板电脑发展起来以后,他们的屏幕虽然不大,但分辨率越来越高!这导致在这些设备上,网页上的内容会看起来会很小,甚至看不清楚,不利于阅读。虽然可以进行缩放,但总是让用户每当打开一个网页都要缩放显然是比较差的设计体验。再者,多列布局的网页在这些小屏幕设备上看起来很是细长,也是不利于阅读的。下面是通过Opera Mobile Emulator模拟 ASUS Nexus 7 浏览我的博客在应用媒体查询前后的对比:

 

图:上图为应用媒体查询前,下图为应用媒体查询后
 

     下面是通过Opera Mobile Emulator模拟 Samsung Galaxy S III 浏览我的博客在应用媒体查询前后的对比:

 

                                 图:左图为应用媒体查询前,右图为应用媒体查询后

 

     通过对比,发现应用了媒体查询后确实比之前显示效果好很多。

 

4.2 媒体查询的核心技术
 

     响应式布局所依赖的核心技术是CSS媒体查询。它可以通过@viewport规则定义视窗区域以设备的物理尺寸为基准,从而解决小屏幕高分辨率下页面内容显示小的问题。可惜的是,目前实现这一规则的浏览器不多,WP8上的IE10和较新版的Opera浏览器实现或部分实现了这个规则。对于Android和iOS等设备上的常用浏览器,需要通过HTML内的<meta>标签来实现相同的目的。这个<meta>标签的声明如下:

<!--HTML Code-->
<meta name="viewport" content="width=device-width, initial-scale=1.0">
     CSS媒体查询的另一个核心是@media规则,这个规则的浏览器支持率还是很高的,除了IE8及其以下版本的浏览器不支持,大多数浏览器都支持。因为我们的响应式布局主要针对的是移动智能设备,而这些设备上的浏览器大都支持@media规则,所以IE8及其以下版本不支持也不是什么大问题。

 

4.3 响应式布局的实现
 

     对于我的博客布局,实现响应式布局的CSS代码代码很简单,具体如下:

@-ms-viewport {
    widthdevice-width;
}
@media (max-width:990px) {
    #homemargin:0 15px; }
}
@media (max-width:640px) {
    #sideBar#mainContentwidth:100%;}
    .postborder-left:none; }
}
     但是这样是很不够的,Android和iOS等设备上的常用浏览器不支持@viewport规则。所以必须得使用HTML内的<meta>标签。可是,博客园几乎所有的HTML模版都没有定义与媒体查询有关的meta标签,我又无法手动更改博客模版的静态HTML页面。怎么办呢?只有通过JavaScript来向HTML内添加<meta>标签了。幸好,我们可以通过博客园后台管理设置里的“页首Html代码”等来添加自己的JS。下面就是所需的JS代码:
<script type="text/javascript">
    $(document).ready(function ()
    {
        var meta = document.createElement("meta");
        meta.name = "viewport";
        meta.content = "width=device-width, initial-scale=1.0";
        $('head').prepend(meta);
    });
</script>

 

 4.4 响应式布局的缺点与改进

 

     使用4.3节介绍的方法实现了响应式布局,但响应式布局也有其缺点。当视窗区域宽度较小时,响应式整个页面的两列布局变成了一列,侧边栏被布局到博客的底部。若博客内容很长, 想到达侧边栏就需要多次翻页。这也是不利于内容访问的。

     如何克服这一缺点呢?我们可以在页面的顶部(或者其他方便的地方) 提供一个跳转锚点链接,使点击这个链接的时候,可以直接跳转到侧边栏。要实现这个功能,一个简单的方法是,先在博客园后台管理设置页首代码,添加一个链接,如:

 

          <a id="jumpToAside" href="#asideAnchor">跳至侧栏</a> 

 

     然后,在博客园后台管理设置公告代码,添加一个链接,如:

 

     <a id="asideAnchor" name="asideAnchor"></a>

 

     这样,就可以克服了响应式布局的缺点,快速地访问侧边栏。我为自己的博客实现了这个功能(跳转链接应用了一些CSS样式),看到这篇文章的你如果使用的是支持媒体查询的浏览器,请将浏览器的宽度缩小到一定程度,会看到页面右上角出现了文本内容为“跳至边栏”的链接,点击它,就可以直接跳转到侧边栏了。如果你使用的是智能手机的竖屏浏览这篇博客,通常也能看到这个跳转链接。

 

5.总结

 

     经我用Chrome、IE10、FireFox、IETester和Opera Mobile Emulator测试,重新修改设计的博客皮肤在在大多数设备与浏览器上的显示效果都还是挺不错的。至少布局上比很多的博客园默认皮肤要好。但是,如果你正使用IE6浏览器浏览本篇博客,你将会看到一个比较丑陋的界面,因为博文中使用了宽度比较大的图片,而IE6不支持max-width属性,大图片打破了布局。但如果你用IE6浏览我其它没有特别大宽度图片的博文,界面就会好很多。至于博客皮肤的其它的设计元素如何就只能根据个人的喜好而定了。现在我所使用的这个皮肤就是自己在本文所要实现的,有条件有兴趣的朋友可以通过手机或者平板电脑浏览我的博客测试下效果。也可以使用支持媒体查询的PC浏览器进行页面缩放改变窗口宽度来测试效果。

     当然,此刻,你所看到的我的博客的当前皮肤(模版)样式不一定与本文中所述相一致,因为我随时有可能修改博客使用的样式。

     由于水平有限,文中错误在所难免,欢迎大家指正或给出建议!
posted @ 2013-03-23 14:11  JiayangShen  阅读(6415)  评论(23编辑  收藏  举报
Top
推荐
收藏
关注
评论