更新,2013-07-12 15:14
加入3种屏幕宽度的判断和样式定义
#leftmenu { position: absolute; left: 35px; width: 350px; height: auto; }
#main { margin-left: 400px; margin-right: 35px; max-width: 870px; overflow: hidden; }
#cnblogs_post_body p img { max-width: 600px; }
.input_my_zzk { width: 310px; }
#top { padding: 0 35px; }
}
@media all and (width:1152px) {
#cnblogs_post_body p img { max-width: 450px; }
#leftmenu { position: absolute; left: 10px; width: 328px; height: auto; }
#main { margin-left: 348px; margin-right: 0; max-width: 769px; overflow: hidden; }
.input_my_zzk { width: 235px; }
#top { padding: 0 10px; }
}
@media all and (width:1024px) {
#cnblogs_post_body p img { max-width: 600px; }
#leftmenu { position: absolute; left: 10px; width: 318px; height: auto; }
#main { margin-left: 338px; margin-right: 10px; max-width: 804px; overflow: hidden; }
.input_my_zzk { width: 225px; }
#top { padding: 0 10px; }
}
更新,2013-07-12 14:35
加入了媒体查询并做调整的定义,可是@media在IE9以下支持不是很好。
因此自适应居中不好法做啊。
#cnblogs_post_body p img { max-width: 600px; }
#leftmenu { position: absolute; left: 10px; width: 200px; height: auto; }
#main { margin-left: 210px; margin-right: 0; max-width: 814px; overflow: hidden; }
.input_my_zzk { width: 110px; }
}
内容提点
Firebug简单介绍
样式定义简介
修改实战
序言
博客园提供了非常丰富的模块,也有很多非常赞的模板,可总是会有一些很喜欢的模板,却又觉得有些美中不足,如果可以自己美化一番,那就更妙了。
那么就从这里开始一次“博皮”的美容之旅。
博客园提供了两种自定义样式的途径:
1、自己创建一个模板,提交给博客园管理团队
2、使用一个现有模板,然后在此基础上编写自定义样式
这里介绍的是第二种
Firebug简单介绍
前端优化调试必须要有一个利器,而火狐上的Firebug插件就是其中之一。
下面就简单的介绍下使用,熟悉的朋友跳过。
定位页面元素
使用这个功能可以轻松的定位到页面的任何html标签。
首先点击,然后鼠标移动到页面的目标位置,然后鼠标按下。
比如这里鼠标移动到【常用链接】,鼠标按下后,就可以看到HTML代码定位到目标位置了。
查看标签的样式定义
了解定位html标签之后,再看看怎么定位查看css样式定义。
通过上面定位html标签,也会马上显示出目标标签的样式定义。
或者是在左边[HTML窗口]点击html标签,右边窗口也会马上显示标签的样式定义。
这里需要说一下的是,注意看右边显示的某定义位于样式文件的第几行,这样有助于快速的找到需要修改的位置。
比如这里的
把自定义的样式复制一个文件中,然后使用一个可以高亮带行数显示的编辑器打开。
调整样式即时显示
Firebug还有一个非常赞的功能
调整样式,立即显示效果
在样式窗口,样式定义位置双击,可以修改定义。
在空白位置双击,可以新建样式定义。
样式定义简介
样式定义需要记住三点要素:选择器、属性定义、属性定义顺序(是否冲突和覆盖)
如果自己想不到好的样式,就参考别人的设计,像支付宝、微博等网站的样式设计的还是不粗的,或者自己喜欢的网站。
然后通过Firebug就可以轻易的获取到定义的样式。
手册
手头有最新的css参考手册,这里推荐http://css.doyoe.com/css.chm 具有最新的css3参考,保持更新。
选择符
具体请参考手册,这里提一个有趣的应用场景
想设置某个模块,而那个模块既没有id也没有class属性,从而无法定位?
没关系,使用关系选择符轻易的搞定。
比如我想设置的【随笔分类】模块恰好符合上面两点的情况。
看到模块上面的
挨的那么近,就拿你来定位了。
先来看看关系选择符是怎么样描述的。
选择符 |
名称 |
版本 |
简介 |
E F |
包含选择符 |
CSS1 |
选择所有被E元素包含的F元素。 |
E>F |
子选择符 |
CSS2 |
选择所有作为E元素的子元素F。 |
E+F |
相邻选择符 |
CSS2 |
选择紧贴在E元素之后F元素。 |
E~F |
兄弟选择符 |
CSS3 |
选择E元素所有兄弟元素F。 |
我们这里要用的就是相邻选择符
#itemListLin_con + h3 + ul { height: 350px; overflow: hidden; }
如此,就可以轻易解决定位的问题。
抓住了目标,当然就是好好蹂躏对方啦。
打开css参考手册,想想搞那些花样吧。
什么?想不到怎么玩?问谷哥度娘吧~~~~” css经典样式”……
修改实战
在博客管理——设置
可以看到
选择一个模板
把自己写的样式复制过来,点击下面的保存。
属性定义
我介绍下自己觉得比较常用的几个属性定义。
margin、padding、float、with、height、min-with、min-height、max-with、max-height、(position top left bottom right)
把这几个属性用好,页面元素基本就不会不受控制的乱窜了。
我使用模板的主要修改
整体调整
原来紧贴边沿修改为左右两边各留出50像素的空,左边栏由200调整宽度为400
如果是在小浏览器或者非最大化的情况,原来的样式定义是挺不错的,但是在大显示器、宽屏、最大化的情况下,就会有些别扭了。
限定文章模块最小宽度为350,防止无意义的缩小。
随笔标签
调整前 |
调整后 |
|
|
这什么玩意啊,都看不清楚!
由于我的标签设置的比较细,所以太多太多了,所以我想把它修改成紧凑式的排列。
|
之前一个标签一行,可想而知这个模块有多长,现在修改完之后,就非常节省空间了。
|
看看样式是怎么定义的。
这里最重要的一点是设置浮动,由于我的标签一般不会很长,所以就没有限定长度,如果你的标签有的很长,则可以设置一个max-width,轻松搞定。
搜索栏调整
这里需要说一下的就是圆角、:focus、:hover及生成背景图片的应用
{
background: linear-gradient(#FFFFFF, #F0F0F0) repeat scroll 0 0 #F0F0F0;
border: 1px solid #CCCCCC;
border-radius: 3px 3px 3px 3px;
cursor: pointer;
font-weight: bold;
text-shadow: 0 1px #FFFFFF;
white-space: nowrap;
}
linear-gradient 在ie10以下不支持~~~~
最新评论区域修改
修改前 |
修改后 |
这个修改很简单,由于前面已经设定了左边区域的宽度,所以,在这里,我只加了一个
把标签li的底部外延边距设置成10像素。
调整前 |
调整后 |
|
|
输入框的调整和上面搜索输入框的调整是一样的原理。
主要是把[使用Ctrl+Enter键快速提交]浮动到左边,通过设置顶边的外延边距来确定位置。 这里也用到了一个相邻选择符。
提交评论 我是直接通过左边外延边距来使其定位在右边。
推荐反对区域的调整
(更新,最后还是把推荐区域放回到右边了...)
原来是固定在文章下面的,为了更加方便园友的操作,嘿嘿,我把它固定在页面的左下角。
为什么要放在左下角,而不是右下角呢?
因为滚动条一般……是在右边的,用户在拉滚动条时,焦点相对也是在右边的。
不是非常重要的信息,一直出现在用户的视野,并不是好的设计,因此我移到了右边,并且把推荐漂到了右边。
这样不会影响用户的浏览,也是相当于用户真的费劲把鼠标移动到最左边去点推荐或反对时,是经过思考的。
好吧,其实我是怕用户拉滚动条的时候,不小心点到了反对……
亲,码字辛苦,给点个推荐吧。
其它
其它地方也陆续进行了一些调整,比如文章区域的字体调整的更大一些;评论回复区的间距;回复的支持反对字体更小一点,避免干扰阅读,链接颜色,线条大小等。
总算看起来更加舒服一点点了。
我使用的模板是Cogitation,修改后的样式代码下载: http://www.cnblogs.com/yelaiju/customcss.aspx?id=57777
原版样式:
http://www.cnblogs.com/klcf0220/
最后一句:样式定义需要记住三点要素:选择器、属性定义、属性定义顺序(是否冲突和覆盖),手册在手。
欢迎回复交流,知必言言必尽。