定制Octopress
在github pages上搭建好octopress博客之后,博客的基本功能就能使用了。如果想自己定制也是没问题的,octopress有较详尽的官方文档,原则上有问题求助官方即可:octopress-help。官方没有包纳的也可以去询问stackoverflow。 当然,中文的看起来总会省事儿点。我做了如下一些总结;)
不会ruby的童鞋特别注意:配置_config.yml的过程中特别注意,配置项『:』后要留空格,否则会报错。
1.装饰边栏
以增加豆瓣展示框为例。参加正反反长大哥的博客How to Embed Douban-Show in Your Octopress Site
2.增加国内的第三方评论
虽然octopress内置的评论系统也很不错,但国内的第三方评论更接地气,将微博、人人等各方SNS都纳入旗下。比较出名的有友言、多说。
这里以唐巧大哥的博文《象写程序一样写博客:搭建基于github的博客》为例,他使用的是友言。
3.定制域名
如果你拥有自己的域名,可以CNAME到github pages上。以我的配置为例(我的域名为biaobiaoqi.me
)。
1.在octopress的source目录下创建CNAME文件,并输入新域名:biaobiaoqi.com
2.在域名管理中,创建或修改A记录,指向207.97.227.245这个地址。
3.创建CNAME记录,www.biaobiaoqi.com -> biaobiaoqi.github.com
这一过程可能需要好几天才能生效,请耐心等待:)
4.让博客中连接在新窗口打开
由于markdown不支持这一语法,如果要自己用html标签实现,又有些违背了markdown以内容为重的立意。
参考博文《在Octopress中为markdown的超链接加上target="_blank"》,可以通过将如下代码添加到 {OCTOPRESS_HOME}/source/_includes/custom/head.html文件末尾来实现:
5.列表的排版
默认情况,所有文字的排头会对齐,但如果有列表项的情况下也如此,列表头就会冲出文章的主体区块了。
在octopress/sass/custom/_layout.scss文件中找到#$indented-lists: true行,去掉#注释即可。
$indented-lists: true
6.404ERROR页面
在ocotopress/source目录下,增加404.markdown,并做出自定义的呃编辑。本博客使用了腾讯公益404,推荐大家使用,为社会贡献一分正能量。公益404
---
layout: page
title: "404 Error"
date: 2013-4-21 02:35
comments: false
sharing: false
footer: false
---
<script type="text/javascript" src="http://www.qq.com/404/search_children.js" charset="utf-8"></script>
7.在侧边栏增加标签云(tag cloud)
octopress默认只有分类,没有标签。这对于博文的组织和管理很不友好。有人开源出了自己定制的tag生成和tag cloud展现的代码,可以引入到自己的博客中来。
详细操作参见博文:《为octopress添加tag Cloud》。不过博文中没有讲解标签云的UI配置参数的使用,为了让UI适应页面,请参考原作者的官方说明:octopress-tag-cloud。我所实践出的较合理的参数值如下
如果想将文章分类(category)也放在侧边栏,可以参考这篇博文:《Octopress - Category List Plug-in》
8.在顶栏增加标签云页面tab
1.生成新网页
2.在顶栏增加新页面
修改source/_includes/custom/navigation.html
<ul class="main-navigation">
<li><a href="{{ root_url }}/">首页</a></li>
<li><a href="{{ root_url }}/blog/categories/tech/">技术</a></li>
<li><a href="{{ root_url }}/blog/categories/life/">生活</a></li>
<li><a href="{{ root_url }}/blog/categories/book/">读书</a></li>
<li><a href="{{ root_url }}/tag-cloud/">标签云</a></li>
<li><a href="{{ root_url }}/about">关于</a></li>
</ul>
在需要的位置增加<li><a href="{{ root_url }}/tag-cloud/">标签云</a></li>
。如此一来,可以在网页顶栏看到『标签云』一栏了。不过此时,点击进入,页面为空。
3.修改标签云页面内容。
修改octopress/source/tag-cloud/index.markdown
,增加标签云执行脚本。
---
layout: page
title: "标签云"
date: 2013-07-10 02:53
comments: true
sharing: true
footer: true
---
#注意,代码中的escape反斜杠在正常使用时需要去掉
#另外,这几个语句不能使用换行。在我的测试环境下,使用换行后,最终的页面上对换行进行了错误的解码,给增加了一个<code>标签,造成了错误的显示。
<ul class="tag-cloud">\{\% tag_cloud font-size: 90-210%, limit: 1000, style: para \%\}</ul>
9.博客末尾增加原文链接、版权等
最近发现有其他小网站未经授权直接copy我的博客内容,在违章的末尾加上版权、原文链接变得很有必要了。
详情参见博客《为octopress每篇文章添加一个文章信息》。
值得注意的是,插件代码中如下几行需要去掉缩进和换行符。原因跟第8节所讲一样,换行符引起了错误的解码,造成了错误的显示。
最后,kevin没有提及的是,为了做好美化,还需要增加一段针这块区域的css:
编辑sass/custom/_style.scss
,在末尾增加如下内容:
这样,原文链接和版权信息就能很好的和正文内容分离开了。
10.给中英文之间加空格
参见博文《给中英文间加个空格》。
Tips
既然是个博客站点,就算是web产品啦,可以考虑下SEO。推荐博文《Octopress中的SEO》
original link:http://biaobiaoqi.github.com/blog/2013/07/10/decorate-octopress/
written by Biaobiaoqi posted at http://biaobiaoqi.github.com
更多推荐
所有评论(0)