博客增加文章点击统计和显示

不蒜子、LeanCloud、谷歌翻译、动态效果

Views:  times Updated on March 27, 2023 Posted by elmagnifico on December 14, 2022

Foreword

想给文章增加点击量的显示以及静态的Blog总的访问量和运行天数等信息,对于静态的Github Pages来说就做不到了,必须得要用一些其他服务来完成这个事情。顺带也增加一下网站的视觉效果

运行时间

合适的位置嵌入一下内容即可

<span id="timeDate">载入天数...</span><span id="times">载入时分秒...</span>
<script>
    var now = new Date(); 
    function createtime() { 
        var grt= new Date("08/10/2018 17:38:00");//在此处修改你的建站时间,格式:月/日/年 时:分:秒
        now.setTime(now.getTime()+250); 
        days = (now - grt ) / 1000 / 60 / 60 / 24; dnum = Math.floor(days); 
        hours = (now - grt ) / 1000 / 60 / 60 - (24 * dnum); hnum = Math.floor(hours); 
        if(String(hnum).length ==1 ){hnum = "0" + hnum;} minutes = (now - grt ) / 1000 /60 - (24 * 60 * dnum) - (60 * hnum); 
        mnum = Math.floor(minutes); if(String(mnum).length ==1 ){mnum = "0" + mnum;} 
        seconds = (now - grt ) / 1000 - (24 * 60 * 60 * dnum) - (60 * 60 * hnum) - (60 * mnum); 
        snum = Math.round(seconds); if(String(snum).length ==1 ){snum = "0" + snum;} 
        document.getElementById("timeDate").innerHTML = "本站已安全运行 "+dnum+""; 
        document.getElementById("times").innerHTML = hnum + " 小时 " + mnum + "" + snum + ""; 
    } 
setInterval("createtime()",250);
</script>

效果还行

统计文章字数

字数很简单就能统计了,如果想要阅读时间做个比例换算就行了。

Words:&nbsp;{{ post.content | number_of_words }}

实际这里会有问题,Jekyll原生的统计字数是基于英文的,所以一旦遇到中文统计就失效了,就导致很多文字明明字很多,却显示一百多个字

https://zhuanlan.zhihu.com/p/433233271

这里作者说Jekyll超过4.1.0版本,这个问题就修复了,而实际上并没有,4.3.2版本这个问题依旧,所以还是要弄其他办法。

我试了一下使用他说的插件办法,立马生效了,而且也不错的样子,之前只显示大概1/10的字数

image-20230322234812941

在仓库创建一个这样的文件_plugins/number_of_words.rb,内容如下即可

module Jekyll
  module Filters
    CJK_CLASS = '\p{Han}\p{Katakana}\p{Hiragana}\p{Hangul}'
    CJK_REGEX = %r![#{CJK_CLASS}]!o
    WORD_REGEX = %r![^#{CJK_CLASS}\s]+!o

    def number_of_words(input)
      cjk_count = input.scan(CJK_REGEX).length
      return input.split.length if cjk_count.zero?
      cjk_count + input.scan(WORD_REGEX).length
    end
  end
end

我另存了一份放在我的tools中了,防止万一丢失了

https://github.com/elmagnificogi/MyTools/blob/master/Jekyll_plugin/number_of_words.rb

不蒜子

https://busuanzi.ibruce.info/

<script async src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script>
            <span id="busuanzi_container_site_pv">本站总访问量<span id="busuanzi_value_site_pv"></span></span>
            <span id="busuanzi_container_site_uv">本站总访客数<span id="busuanzi_value_site_uv"></span></span>
            <span id="busuanzi_container_page_pv">本页总访问量<span id="busuanzi_value_page_pv"></span></span>

总体来说非常简单易用,但是唯一的问题是,数据不在你手上,而且如果有一天不蒜子没了,那么你的所有统计信息都没有了。

同时如果已经运行了很久,就无法再统计数量了,不蒜子暂停注册了,不能修改初始值了,所以就有点困难。

如果有一天不蒜子没了,也有下面的替代品,可以自己部署,自己存储

https://github.com/soxft/busuanzi

https://github.com/zkeq/Busuanzi

https://github.com/zkeq/Busuanzi_backend_self

https://github.com/qiushaocloud/site-counter

顺带在运行时间里做了一个统计的补充,由于不能注册,以前的数量没有了,所以手动加了一个补充

                <p class="copyright text-muted">
                    <span id="busuanzi_container_site_pv">本站总访问量<span id="fix_site_pv"></span>次<span id="busuanzi_value_site_pv" style="display: none;"></span></span>
                    <span id="busuanzi_container_site_uv">访客数<span id="fix_site_uv"></span>人<span id="busuanzi_value_site_uv" style="display: none;"></span></span>
                    <br>
                    <span id="timeDate">载入天数...</span><span id="times">载入时分秒...</span>
                    <br>
                    Copyright &copy; Elmagnifico's Blog 2025
                    <br>
                    Theme by <a href="https://github.com/elmagnificogi/elmagnificogi.github.io">elmagnifico</a>
                </p>
<script>
    var now = new Date();
    var getStatistics = false;
    var changeDone = false;
    function createtime() {
        var grt= new Date("01/11/2015 20:01:26");
        now.setTime(now.getTime()+250);
        days = (now - grt ) / 1000 / 60 / 60 / 24; dnum = Math.floor(days);
        hours = (now - grt ) / 1000 / 60 / 60 - (24 * dnum); hnum = Math.floor(hours);
        if(String(hnum).length ==1 ){hnum = "0" + hnum;} minutes = (now - grt ) / 1000 /60 - (24 * 60 * dnum) - (60 * hnum);
        mnum = Math.floor(minutes); if(String(mnum).length ==1 ){mnum = "0" + mnum;}
        seconds = (now - grt ) / 1000 - (24 * 60 * 60 * dnum) - (60 * 60 * hnum) - (60 * mnum);
        snum = Math.round(seconds); if(String(snum).length ==1 ){snum = "0" + snum;}
        document.getElementById("timeDate").innerHTML = "本站已运行 "+dnum+" 天 ";
        document.getElementById("times").innerHTML = hnum + " 小时 " + mnum + " 分 " + snum + " 秒";
        // 补充统计
        if(!getStatistics && ""!=document.getElementById("busuanzi_value_site_uv").innerHTML){getStatistics = true;}
        if(getStatistics && !changeDone) {
            site_pv = document.getElementById("busuanzi_value_site_pv").innerHTML;
            site_uv = document.getElementById("busuanzi_value_site_uv").innerHTML;
            site_pv_num = parseInt(site_pv,10) + 1145147;
            site_uv_num = parseInt(site_uv,10) + 981462;
            document.getElementById("fix_site_pv").innerHTML = site_pv_num;
            document.getElementById("fix_site_uv").innerHTML = site_uv_num;
            changeDone = true;
        }
    }
setInterval("createtime()",250);
</script>

LeanCloud

使用LeanCloud的数据统计服务

https://www.leancloud.cn/

LeanCloud经历了比较多的变动,之前出现了一次域名被禁止解析,然后js文件直接拉不到,很多人都选择了把js存本地,然后又能用了

https://forum.leancloud.cn/t/av-core-mini-0-6-4-js-av-min-js/22777

但是后来,直接停止国内未绑定域名的服务,就导致很多人又搬去了国外站,再接着就是国外依然能访问国内,LeanCloud国际为了合规,不允许国内使用了,直接把国外的访问屏蔽了。

https://forum.leancloud.cn/t/2022-8/25408

现状就是如果使用CND的js,各方面都配置正确了依然会提示错误,他要求你绑定域名

Access to XMLHttpRequest at 'https://recukngv.api.lncldglobal.com/1.1/classes/Counter?where=%7B%22time%22%3A%7B%22%24gte%22%3A0%7D%7D' from origin 'http://elmagnifico.tech' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.
(index):1383 query error:Request has been terminated
Possible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc. [N/A GET https://recukngv.api.lncldglobal.com/1.1/classes/Counter]

https://recukngv.api.lncldglobal.com/1.1/classes/Counter?where=%7B%22time%22%3A%7B%22%24gte%22%3A0%7D%7D net::ERR_FAILED

badge

一个可以用来统计任何一个页面的标签,不好的点就是这个标签需要每次手动申请,挺麻烦的

https://www.v2ex.com/t/702702

其他修改

动态波纹

很简单的效果就能给网页加一点动态

    <!-- wave  -->
    <link rel="stylesheet" href="/css/wave.css"/>
    
	<!-- waveoverlay start -->
    <div class="preview-overlay">
        <svg class="preview-waves" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 24 150 28" preserveAspectRatio="none" shape-rendering="auto">
        <defs>
            <path id="gentle-wave" d="M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z"></path>
        </defs>
        <g class="preview-parallax">
            <use xlink:href="#gentle-wave" x="48" y="0" fill=var(--gentle-wave1)></use>
            <use xlink:href="#gentle-wave" x="48" y="3" fill=var(--gentle-wave2)></use>
            <use xlink:href="#gentle-wave" x="48" y="5" fill=var(--gentle-wave3)></use>
            <use xlink:href="#gentle-wave" x="48" y="7" fill=var(--gentle-wave)></use>
        </g>
        </svg>
    </div>
    <!-- waveoverlay end -->

引用自

https://sysin.org/

背景增加彩带

<!-- ribbon -->
<script type="text/javascript" src="/js/ribbonDynamic.js"></script>

类似的效果

增加顶部进度条

    <!-- top processbar -->
    <link rel="preload" href="{{ site.BASE_PATH }}/css/style.css" as="style" onload="this.onload=null;this.rel='stylesheet'">
    <noscript><link href="{{ site.BASE_PATH }}/css/style.css" rel="stylesheet"></noscript>

    <!-- 文章进度条 -->
    <div class="progress-indicator" style="width: 0%;"></div>
    
    <!-- 文章进度条:在style.css里面更改进度条样式 -->
<script type="module">
  /* 顶部进度条 */
  (function() {
    var $w = $(window);
    var $prog2 = $('.progress-indicator');
    var wh = $w.height();
    var h = $('body').height();
    var sHeight = h - wh;
    $w.on('scroll', function() {
    window.requestAnimationFrame(function(){
      var perc = Math.max(0, Math.min(1, $w.scrollTop() / sHeight));
      updateProgress(perc);
    });
    });

    function updateProgress(perc) {
    $prog2.css({width: perc * 100 + '%'});
    }
  }());
</script>

引用自

https://blog.whuzfb.cn/

返回顶部按钮

    <!-- back-to-top -->
    <div id="back-top">
        <a href="#section" data-toggle="tooltip" data-placement="top" title="top">
        <i class="fa fa-chevron-up" aria-hidden="true"></i>
        </a>
    </div>
    
    <script type="module">
        $('#back-top').hide();
        $(document).ready(function () {
        $(window).scroll(function () {
        if ($(this).scrollTop() > 250) {
          $('#back-top').fadeIn();
        } else {
          $('#back-top').fadeOut();
        }
        });
        $('#back-top a').click(function () {
        $('body,html').animate({
          scrollTop: 0
        }, 800);
        return false;
        });
      });
      </script>

效果如下:

内置谷歌翻译

有些老外看不懂,还要内置翻译一下

首先修改CSS,替换谷歌翻译的原生UI,有点难看

#google_translate_element .goog-te-gadget-simple {
  background-color: #fff0;
  border-left: none; 
  border-top: none; 
  border-bottom: none; 
  border-right: none; 
  font-size: none; 
  padding-top: none; 
  padding-bottom: none;
  zoom: 1;
  display: inline;
}

#google_translate_element .goog-te-gadget-simple img:first-child{display: none;}

#google_translate_element .goog-te-gadget-simple .goog-te-menu-value span:first-child{display: none;}

#google_translate_element .goog-te-gadget-simple .goog-te-menu-value:before {
  content: 'Translate'
}

然后加入谷歌翻译

<div id="google-translate">
<div id="google_translate_element"></div>
</div>

<!-- google-translate -->
<script async="async" type="text/javascript" src="//translate.google.com/translate_a/element.js?cb=googleTranslateElementInit"></script>
<script type="text/javascript">
var userLang = navigator.language || navigator.userLanguage || navigator.languages;
function googleTranslateElementInit() {
new google.translate.TranslateElement({
    includedLanguages: 'en,hi,es,zh-TW,fr,ar,bn,ru,pt,de,ja,ko,it',
    autoDisplay: true,
    pageLanguage: 'zh-CN',
    multilanguagePage: false,
    layout: google.translate.TranslateElement.InlineLayout.SIMPLE
    //layout: google.translate.TranslateElement.FloatPosition.TOP_RIGHT
}, 'google_translate_element');
}
</script>

效果还行,至少UI上统一了

Jekyll支持Mermaid

post.html中增加

<script src="https://cdnjs.cloudflare.com/ajax/libs/mermaid/8.0.0/mermaid.min.js"></script>
<script>
  var config = {
    startOnLoad:true,
    theme: 'forest',
    flowchart:{
            useMaxWidth:false,
            htmlLabels:true
        }
  };
  mermaid.initialize(config);
  window.mermaid.init(undefined, document.querySelectorAll('.language-mermaid'));
</script>

下面的代码就变成了mermaid图了

graph TD;
A[Christmas] -->|Get money| B(Go shopping);
B --> C{Let me think};TD
C -->|One| D[Laptop];
C -->|Two| E[iPhone];
C -->|Three| F[fa:fa-car Car];

中文独立博客列表

https://github.com/timqian/chinese-independent-blogs

之前就加入了,只是一直忘了写,这里有各种中文博客,有需要可以自己提PR,格式模仿上一位即可,最好是带上自己的RSS订阅链接

Feeds Pub相当于也是一个RSS的阅览器,提交以后可以在设置里认证一下自己的网站

目前使用Feeds Pub的人不是很多,不过如果有需要的话,完全可以通过爬这份列表,拿到各种技术文章更新

Summary

更新了一下视觉效果,感觉好像比以前加载慢了一点

Quote

https://shangzg.top/zh-cn/2021-10-19-hugo-personal-blog-adds-valine-comment-system/

https://imooner.com/2019/06/08/%E5%8D%9A%E5%AE%A2%E6%90%AD%E5%BB%BA%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9/

https://docs.leancloud.app/sdk_setup-js.html

https://blog.whuzfb.cn/

https://github.com/zfb132/zfb132.github.com/blob/master/index.html

https://qchaha.github.io/2018/09/19/homepageStatistics.html

https://www.cnblogs.com/zfb132/p/10665385.html

https://stackoverflow.com/questions/9306015/modifying-element-from-google-translate-translateelement-results/46306852#46306852

https://github.com/zfb132/zfb132.github.com

https://zhuanlan.zhihu.com/p/433233271

https://eipi10.cn/others/2019/12/07/jekyll-markdown-skills/