视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Hexo博客Jacman主题的优化增加博客打赏功能_html/css_WEB-ITnose
2020-11-27 16:40:07 责编:小采
文档
–本博客5月19日优化

使用Hexo这款博客框架已经很久了,期间也一直在摸索,一次次地修改代码,看效果,修改,看效果…,现在已经大致熟悉了整个框架的结构,能够自主完成对主题的修改了。

接下来可以考虑写一篇解析Hexo框架的文章,一来加深自己对框架的理解,方便后续研究,而来也为其他刚开始接触Hexo的童鞋提供一些方法,让他们能够更快地适应,熟悉这个框架。

今天偶然看到一个打赏功能,于是想在自己的博客上实现一下,虽然自觉自己的文章还有待加强,但是客官您随意啦。听说,打赏我的人最后都找到了真爱~

灵感起源于 这篇文章 ,初始采用的是这篇文章的最终版代码,后来自己进行了大量的修改,并且嵌入到了框架中。接下来,就来讲讲具体怎么做吧。

什么叫嵌入到博客中?为什么这么干?

嵌入到博客中,简单说来,就是嵌入到博客模板中,不是单纯地贴HTML代码来改变显示内容,而是将自己要显示的信息写在主题的配置文件 _config.yml 中,然后通过HTML模板在网页中显示,这样,每次想修改显示内容的时候,就不用去艰难地寻找具体的ejs文件,然后找到具体的HTML代码,然后找到具体的标签位置再去修改了,而是打开 _config.yml ,直接编辑,搞定。这样也有利于标准化,这才是一个轮子应有的功能。之前我做很多主题优化的时候,很多都是直接粘HTML代码,代码短的话无伤大雅,但是代码长的话,随着时间的推移,整个代码就没法看了,不利于维护。

要做什么?

我们要实现的目标就是只需在 themes\jacman\_config.yml 文件中添加如下语句:

donate: enable: true text: 打赏我的人,运气都不会太差~ wechat: http://7xsl28.com1.z0.glb.clouddn.com/wechatpay.png alipay: http://7xsl28.com1.z0.glb.clouddn.com/alipay.jpg web: true

即可实现如本文最下方的样式:

首先有一个按钮,如果读者不想打赏,自然不会去点它:

但是如果点击按钮的话,就转而显示如下效果:

读者用微信或者支付宝扫描二维码即可实现打赏功能。

这里也可以添加一个网页版的支付宝付款链接,这里采用的是云打赏,因为云打赏支持支付宝支付和微信支付,而微信支付还是要扫码,支付宝的话倒是可以选择网页支付和扫码支付,反正感觉稍微有点繁琐,跟外卖付款的程序一样,但是我估计读者肯定没有外卖付款那么积极的,不过既然做了,还是贴出来。将上面的web值改为false可以不显示web端付款链接,及中间那个“赏”字。

怎么做?

因为我们想要将打赏功能嵌入到每一篇博客当中,所以我们需要改动文章显示的HTML模板。 找到 themes\jacman\layout\_partial\post\article.ejs 这就是文章的HTML模板文件,在 ... 的下面, <%- partial('footer') %> 的上面插入如下HTML代码:

<% if (theme.donate) { %>  
------------------------------------------------------------------------------------------------------------------------------
<%= theme.donate.text %>
------------------------------------------------------------------------------------------------------------------------------
<% if(theme.donate.web) { %>
显示全文
专题