Hexo博客Jacman主题的优化增加博客打赏功能_html/css_WEB-ITnose

html教程评论605 views阅读模式

–本博客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) { %> <% } %> <%= theme.donate.text %> <% } %>

第95行开头的那段代码可以不加。 整个逻辑就是: 判断是否需要显示打赏模块,是的话,就显示。 显示的内容有两种,按钮和二维码,首先将二维码隐藏起来,等到用户按动按钮,则将按钮隐藏起来,二维码显示出来。

这样我们的打赏功能就做好了,是不是很简单呢?你也可以试试哦。如果这篇文章对你有用,你不妨也打赏下我呢~ Hexo博客Jacman主题的优化增加博客打赏功能_html/css_WEB-ITnose

企鹅博客
  • 本文由 发表于 2020年9月19日 08:30:45
  • 转载请务必保留本文链接:https://www.qieseo.com/357907.html

发表评论