为Next主题添加多说评论系统
2017-03-21 21:10
211 查看
前言
几个月前,在好奇心的鼓动下,利用Github Pages和
Hexo以及
Next主题搭建一个属于自己的个人主站,由于时间伧俗,搭建成功后就没有好好完善一下,可以参照文章徒手教你建自己的博客,文章里有搭建免费博客的详细步骤。
这周末没有加班,静下心写了篇文章,发布成功后,却又遇到
Github Pages更新的原因导致博客的页面出现空白,又顺手写了一篇解决页面空白问题的博客,文章为关于hexo主题next博客加载空白页的处理,文章记录了出现问题原因和解决的多种方式。
解决完问题,本以为没有什么优化的了,此刻,看到别人的博客都可以评论和分享,后来考虑了一下,评论的功能对于反馈博客中问题很有帮助,于是乎,决定搞一下。
在添加评论的过程中,主要遇到下面的三个问题:
-
1、如何选取合适评论系统;
-
2、添加评论系统后,如何根据文章对评论进行区分;
-
3、如何解决评论后的邮件提醒。
后续的内容将围绕上述三个问题进行展开。
选取合适评论系统
有disqus和
多说两种评论系统。
-
disqus加载速度较慢,并且用户必须先注册
disqus用户才能评论,流程很繁琐,最重要的是需要翻墙,这可是致命一击啊。
而
多说可以很好避开上述的缺点,加载速度快、利用社交账号登录就能评论、还带有邮件提醒功能,对比一下,简直天壤之别,果断选择
多说。
安装多说
进入多说网站,点击我要安装,具体设置如下图:
点击
创建,选择
通用,就会显示一段嵌入评论的通用js代码,如下图:
替换主题中指定的文件
首先,说一下我使用的是Next主题,需要修改代码文件是
_config.yml中
duoshuo_shroname,如下:
duoshuo_shortname: 填写上述步骤注册的shroname
还需要修改目录
themes/next/layout/_partials/comments.swig下的
comments.swig。
若你是
landscape主题,需要修改
themes\landscape\layout\_partial\article.ejs目录下的
article.ejs文件
找到原文件中的被替换代码:
<div class="ds-thread" data-thread-key="{{ page.path }}" data-title="{{ page.title }}" data-url="{{ page.permalink }}"> </div>
替换的代码如下:
添加评论邮件提醒
多说自带的邮件提醒功能是不支持主动评论提醒的,比如说在某一篇博客中,有人主动评论留言的话,
多说此时是不会邮件提醒的。
多说所谓的邮件提醒是以别人回复别人的评论为前提的,即你不是回复他人的评论博主就收不到你评论回复的提醒。
从这一点上看,
多说这一功能有失人性化的设计,故自己动手解决这个邮件提醒不完整的问题。
从分析
多说提供的API入手,同步用户到多说和评论框调用代码参数说明,得知可以使用
data-author-key变量设置主动邮件提醒。
我们需要做的是,自定义同步一个用户到
多说服务器,并将该用户设置成作者身份,进而取得该用户在站点的ID,将该ID赋值给
data-author-key加在
多说的评论框里即可。
开始动手….
在桌面或其他目录下,新建一个文件夹,命名为
js或者其他,进入该文件夹,利用终端执行下面的命令:
npm install --save-dev request
需要等上几分钟,此时你可以进行下一步了。
利用
sublime或其他工具新建一个
myuser.js文件,将下面的代码复制进文件夹,并修改相应的
data数据
var http = require('request'); var data = { 'short_name' : '', // 你的short_name,后台管理那里可以看到 'secret' : '', // 密钥,后台管理那里可以看到 'users[0][user_key]' : '1', // 用户在站点的ID,就是后面需要设置的 data-author-key值,可以随意设置,这里默认为1吧 'users[0][name]' : '', // 显示的名字 'users[0][email]' : '', // 提醒的邮箱 'users[0][role]' : 'author'// 用户的类型,设置为作者 }; http.post({url:'http://api.duoshuo.com/users/import.json', form: data}, function (error, response, body) { if (!error && response.statusCode == 200) { console.log('Post data to Duoshuo success'); } else{ console.log('Post data to Duoshuo fail'); } });
将上面代码中的数据按照自己的多说账户设置好之后,执行以下命令完成数据同步到多说服务器:
node myuser.js
若输出为
Post data to Duoshuo fail那就重新检查以下
data数据是否修改正确;
若输出为
Post data to Duoshuo success,那么就登录到
多说的后台,在用户那里看到新添加的用户,如下所示;
若后台显示的角色不是作者,可以手动改成作者。
去目录
themes/next/layout/_partials/comments.swig,修改文件
comments.swig中的那段代码(见上面描述)为:
<section id="comments"> <!-- 多说评论框 start --> <div id="ds-thread" class="ds-thread" data-thread-key="{{ page.path }}" data-title="{{ page.title }}" data-url="{{ page.permalink }}" data-author-key="{{ theme.duoshuo_info.data_author_key }}"></div> <!-- 多说评论框 end --> <!-- 多说公共JS代码 start (一个网页只需插入一次) --> <script type="text/javascript"> var duoshuoQuery = {short_name:"shortTime"}; (function() { var ds = document.createElement('script'); ds.type = 'text/javascript';ds.async = true; ds.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') + '//static.duoshuo.com/embed.js'; ds.charset = 'UTF-8'; (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(ds); })(); </script> <!-- 多说公共JS代码 end --> </section>
上述代码与之前的比较,可以看出其实就是增加了一个变量:
data-author-key="{{ theme.duoshuo_info.data_author_key }}"
这里设置好之后,修改主题下的
_config.yml文件,增加一行配置,如下:
duoshuo_info: data_author_key: 1 #此处填写上面js脚本中的data变量中的users[0][user_key]的值,因为上面为1,这里我就填写为1了
到这里基本的工作就完成了,重新发布博客,就可以使用主动评论邮件提醒了。
参照我的博客
PS一句,这种邮件提醒不是实时提醒,而是每天一封汇总邮件。如果你中途查看了这个评论的话,也是不会邮件提醒的。
以上内容,就是我对常用算法的简单总结。大家如有其他意见欢迎评论。
扫一扫下面的二维码,欢迎关注我的个人微信公众号攻城狮的动态(ID:iOSDevSkills),可在微信公众号进行留言,更多精彩技术文章,期待您的加入!一起讨论,一起成长!一起攻城狮!
相关文章推荐
- hexo使用next主题,并且使用”多说“给博客的文章添加评论功能
- hexo 博客next主题集成gitment或者gitalk评论系统
- Hexo博客yelee主题添加Gitment评论系统
- NEXT主题:使用”多说“给博客的文章添加评论功能
- Hexo NexT主题内集成gitalk评论系统
- 在Jekyll博客添加评论系统:gitment篇
- Hexo站点优化更换主题添加多说评论增加百度统计
- 给hexo个人博客 next主题添加背景图片
- 换主页轮播的主题图片(3、保存添加)---轻开电子商务系统(企业入门级B2C网站)
- Hexo + yilia 主题 +githubpages博客添加友言评论功能
- Github pages + Hexo 博客 yilia 主题使用畅言评论系统
- 为NexT主题添加文章阅读量统计功能
- Emacs添加主题插件(Win系统)
- 方维分享系统二次开发, 给评论、主题、回复、活动 加审核的功能
- Hexo+Next主题 文章添加阅读次数,访问量等
- Hexo的Next主题增加畅言评论
- 换主页轮播的主题图片(2、添加)---轻开电子商务系统(企业入门级B2C网站)
- Hexo个人免费博客(三) next主题、评论、阅读量统计和站内搜索
- 【分享】博客美化(5)为博客或系统添加一个强大的评论系统
- hexo 添加disqus评论系统