Hexo主题maupassant博客搭建相册

我的博客:https://wiki.hushhw.cn/posts/6ff333ed.html

之前一直想要在博客里加一个相册的功能,自己折腾无果后,转入使用主题 yilia ,该主题是将其在ins上的相册转过来,我也刚好也是想把ins上的照片转过来,太喜欢这个app了,所以这个主题真的是深得我心。可是,男人都是善变的,我现在又转入了新主题 Manpassant ,于是开始了我的漫漫迁移路。

本篇文章仅介绍如何在Manpassant主题上迁移yilia上的相册功能,如何获取ins上的照片,以后有时间再补充介绍。

准备工作

首先你得搭建好你的相册库,无论是本地存储还是用github、七牛云都可以。

生成相册页面

$ hexo new page "photos"

执行完毕后找到 source/photos 文件夹下 index.md 进行修改,Manpassant 支持是否显示侧栏两种 page 模式,设置layout为layout: page则显示双栏,若需要单栏页面,就将layout设置为 layout: single-column

我的配置:

layout: single-column
type: "photos"
title: 相册
noDate: 'true'
comments: 'true'
copyright: false

正文代码部分如下:

  • 前面三个link的文件都要一起放在photos文件夹中,点击之后可以下载
  • 第8行超链接可以替换成你自己的ins网页
<link rel="stylesheet" href="./ins.css">
<link rel="stylesheet" href="./photoswipe.css"> 
<link rel="stylesheet" href="./default-skin/default-skin.css"> 

<div class="instagram itemscope">
    <section class="archives album">
        <ul class="img-box-ul">
            <a href="https://www.instagram.com/hushhw/" target="_blank" class="open-ins">图片来自instagram,正在加载中…</a>
        </ul>
    </section>
</div>
<script>
    function add0(m){return m<10?'0'+m:m };
    function getDate(timeString) {
        var time = new Date(parseInt(timeString) * 1000);
        var y = time.getFullYear();
        var m = time.getMonth()+1;
        var d = time.getDate();
        return y+'-'+add0(m)+'-'+add0(d);
    };
</script>
<script>
    (function() {
        var loadScript = function(path) {
            var $script = document.createElement('script')
            document.getElementsByTagName('body')[0].appendChild($script)
            $script.setAttribute('src', path)
        }
        setTimeout(function() {
            loadScript('./ins.js')
        }, 0)
    })()
</script>

此时,页面的基本样式已经完成,完成图如下:

image

此时若点击图片试图查看大图,浏览器将会报错

Uncaught ReferenceError: PhotoSwipe is not defined 

引入JS文件

前面添加的photoswipe.cssdefault-skin.css是使用photoswipe来查看相册图片,具体可以参考网址 photoswipe。其实Manpassant主题已经内置了fancybox来查看图片,那为什么还要使用OpenSwipe呢?因为我们想要实现显示在网页上的图片是压缩版本,点击之后图片显示未压缩版本(其实主要是因为yilia主题用的就是这个,我只会魔改。。。)

现在继续添加js文件到主题文件夹中,找到themes/maupassant/source/js文件夹下面两个文件放入其中(可以从PhotoSwipe项目中下载):

在主题目录layout/_partial下新建文件openswipe.pug写入:

script(type='text/javascript', src=url_for(theme.js) + '/photoswipe.min.js' + '?v=' + theme.version)
script(type='text/javascript', src=url_for(theme.js) + '/photoswipe-ui-default.min.js' + '?v=' + theme.version)

之后,在base-without-sidebar.pug文件最后加上一句include _partial/openswipe.pug,如果你前面选的是双栏页面使用的是layout: page,那么你应该在base.pug文件中添加。

完成到这里,OpenSwipe的配置基本完成,当你点击图片时浏览器报错将是

Uncaught TypeError: Cannot read property 'firstChild' of undefined

点击图片判断

找到文件single-column.pug,加入判断语句:

 if page.type == "phtos"
     div(class="pswp" tabindex="-1" role="dialog" aria-hidden="true")
      div(class="pswp__bg")
      div(class="pswp__scroll-wrap")
       div(class="pswp__container")
        div(class="pswp__item")
        div(class="pswp__item")
        div(class="pswp__item")
       div(class="pswp__ui pswp__ui--hidden")
        div(class="pswp__top-bar")
         div(class="pswp__counter")
         button(class="pswp__button pswp__button--close" title="Close (Esc)")
         button(class="pswp__button pswp__button--share" title="Share")
         button(class="pswp__button pswp__button--fs" title="Toggle fullscreen")
         button(class="pswp__button pswp__button--zoom" title="Zoom in/out")
         div(class="pswp__preloader")
          div(class="pswp__preloader__icn")
           div(class="pswp__preloader__cut")
            div(class="pswp__preloader__donut")
        div(class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap")
         div(class="pswp__share-tooltip")
        button(class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)")
        button(class="pswp__button pswp__button--arrow--right" title="Next (arrow right)")
        div(class="pswp__caption")
         div(class="pswp__caption__center")

由于该主题文件都是.pug,而本人对jade并不熟悉,所以查了一下基本语法莫改了一下javascript代码。

添加完成之后,相册页面也就完结撒花啦!

使用流程

  • 使用nodejs-ins工具生成图片及ins.json文件
  • 正常使用hexo g -d更新博客
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,081评论 4 62
  • 十月,本溪老边沟的红叶。 最美如红叶,虽红不是春。 谦谦君子。
    淡然YH阅读 178评论 2 1
  • 希望毕业两年后找到自己喜欢的工作,有一份稳定的收入和一个很爱很爱我的男朋友~当然我也很爱他呀~
    云从足下生阅读 234评论 0 0
  • 机缘巧合知道了简书 认真便捷注册了账号 郑重其事的写下第一篇文章 简书生涯从此踏上征程
    小团子妈阅读 188评论 0 2