在 github pages 上搭建好 octopress 博客之后,博客的基本功能就能使用了。如果想自己定制也是没问题的,octopress 有较详尽的官方文档,原则上有问题求助官方即可:octopress-help。官方没有包纳的也可以去询问 stackoverflow。 当然,中文的看起来总会省事儿点。我做了如下一些总结;)
不会 ruby 的童鞋特别注意:配置_ config.yml 的过程中特别注意,配置项『:』后要留空格,否则会报错。
另外,一些『土方法』可能并不利于程序的维护可扩展,有空再仔细研究,大家将就着用吧;).
0.安装第三方主题
之所以把这一点标记为 0,是因为在博主刚刚经历了博客主题的更新后,惨烈的发现需要重新配置包括评论、百度统计在内的不少东西。
应该是自己在做定制化的过程中乱修改源码(这是一种很不可取维护方式,使软件难以持续扩展)造成的,又或者 octopress 框架本身对定制化扩展的支持比较弱(对 ruby 不熟,对 octopress 也一知半解,我不确定是不是这个原因)。
简而言之,初接触 octopress 的朋友们,建议先安装第三方主题,再参考以下定制方法。
我使用的第三方主题是『whitelake』。
安装过程很简单:
1 2 3 4 |
|
注意,执行rake install['whitelake']
之后,直接使用rake preview
浏览网页会遇到很多瑕疵,rake generate
之后再rake preview
就没问题了。
更多第三方插件和主题资源,参见官方 repo 的 wiki.
1.装饰边栏
以增加豆瓣展示框为例。参加正反反长大哥的博客 How to Embed Douban-Show in Your Octopress Site
2.增加评论和分享功能
虽然 octopress 内置的 disqus 评论系统很不错,但在国内的使用并不普及。相比之下,友言、多说等第三方评论则更接地气,可以利用到微博、人人等 SNS 账号。
2.1 友言
本博客采用了友言。首先注册友言的账号,如果不注册,虽然也能实现评论功能,但没有后台管理整个站点的评论会十分纠结。注册完成之后,选择获取代码,将这串代码贴入相应的位置,即可实现第三方评论。
在路径$OCTOPRESS/source/_includes/post/
上创建文件youyanandjiathis.html
,功能代码放入其中。
2.2 加网
分享方面,本博客使用了加网。注册后,在更多高级自定义功能中,可能自定义不同的分享按钮,生成代码后,也将生成的代码贴入$OCTOPRESS/source/_includes/post/youyanandjiathis.html
中。
现在,youyanandjiathis.html 的样子如下(需要注意,自己使用时,uid 显然是不一样的啦)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
2.3 将功能增加到博客中
功能代码已经都在 youyanandjiathis.html 中了,接下来是让 blog 使用到这些功能代码。
首先在_ config.yml 中增加开关:
1 2 |
|
然后在$OCTOPRESS/source/_includes/post/sharing.html
中的,根据开关comment_and_share
引入对应的功能代码post/youyanandjiathis.html
,类比于默认实现中的<facebook_like>
部分。代码如下(使用时,先去掉反斜杠):
1 2 3 |
|
2.4 友言验证
另外,需要在友言的后台处理评论,甚至做一些定制化处理,需要通过友言的验证。详情在友言的管理员后台可见。
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 文件末尾来实现:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
|
5.列表的排版
默认情况,所有文字的排头会对齐,但如果有列表项的情况下也如此,列表头就会冲出文章的主体区块了。
在 octopress/sass/custom/_layout.scss 文件中找到#$indented-lists: true 行,去掉#注释即可。
1
|
|
6.404ERROR 页面
在 ocotopress/source 目录下,增加 404.markdown,并做出自定义的呃编辑。本博客使用了腾讯公益 404,推荐大家使用,为社会贡献一分正能量。公益 404
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
7.在侧边栏增加标签云(tag cloud)
octopress 默认只有分类,没有标签。这对于博文的组织和管理很不友好。有人开源出了自己定制的 tag 生成和 tag cloud 展现的代码,可以引入到自己的博客中来。
详细操作参见博文:《为 octopress 添加 tag Cloud》。不过博文中没有讲解标签云的 UI 配置参数的使用,为了让 UI 适应页面,请参考原作者的官方说明:octopress-tag-cloud。我所实践出的较合理的参数值如下
1 2 |
|
如果想将文章分类(category)也放在侧边栏,可以参考这篇博文:《Octopress - Category List Plug-in》
8.在顶栏增加标签云页面 tab
1.生成新网页
1
|
|
2.在顶栏增加新页面
修改source/_includes/custom/navigation.html
1 2 3 4 5 6 7 8 |
|
在需要的位置增加<li><a href="/tag-cloud/">标签云</a></li>
。如此一来,可以在网页顶栏看到『标签云』一栏了。不过此时,点击进入,页面为空。
3.修改标签云页面内容。
修改octopress/source/tag-cloud/index.markdown
,增加标签云执行脚本。
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
9.博客末尾增加原文链接、版权等
最近发现有其他小网站未经授权直接 copy 我的博客内容,在违章的末尾加上版权、原文链接变得很有必要了。
详情参见博客《为 octopress 每篇文章添加一个文章信息》。
值得注意的是,插件代码中如下几行需要去掉缩进和换行符。原因跟第 8 节所讲一样,换行符引起了错误的解码,造成了错误的显示。
1 2 3 4 5 6 |
|
最后,kevin 没有提及的是,为了做好美化,还需要增加一段针这块区域的 css:
编辑sass/custom/_style.scss
,在末尾增加如下内容:
1
|
|
这样,原文链接和版权信息就能很好的和正文内容分离开了。
10.给中英文之间加空格
参见博文《给中英文间加个空格》。
特别注意 ruby 文件的编码:复制博文中的代码时,需要去掉前几行的描述性注释,让#encoding:UTF-8
语句暴露在.rb 文件的第一句。否则,rake generate
时,会报错无法识别\p{Han}
。
Tips
既然是个博客站点,就算是 web 产品啦,可以考虑下 SEO。推荐博文《Octopress 中的 SEO》