2

我正在尝试编写一个 Jekyll 插件,它计算图像的纵横比并将其包装在该大小的容器中,以避免在加载页面时重排。我正在使用fastimage来计算比率,现在它看起来像这样:

require 'fastimage'

module Jekyll
  class PlaceholderImageTag < Liquid::Tag

    def initialize(tag_name, markup, tokens)
      super
      @image_url = 'image_url'
    end

    def render(context)
      @index = Liquid::Template.parse("{{ forloop.index | minus: 1 }}").render(context)
      @base_url = Liquid::Template.parse("{{ site.#{@image_url} }}").render(context)
      @src = Liquid::Template.parse("{{ page.images[#{@index}].image }}").render(context)

      @size = FastImage.size("http://localhost:4000/public/images/"+@src)
      @ratio = (@size[1]*1.0/@size[0])*100

      placeholder = "<div class='placeholder' style='padding-bottom:#{@ratio}%'>"
      placeholder += "<img src=\"#{@base_url}\/#{@src}\"/>"
      placeholder += "</div>"
    end
  end
end

Liquid::Template.register_tag('placeholder_img', Jekyll::PlaceholderImageTag)

问题是,当我在本地(localhost:4000)构建我的站点时,FastImage 返回和错误 - 如果我将 FastImage 指向不同的本地服务器(如 MAMP)或我的生产 URL,它工作得很好,但是使用 jekyll 服务器根本失败。

是否可以在不指向单独服务器的情况下让 FastImage 工作?

4

1 回答 1

0

我发现如果在启动 jekyll 之前站点源代码中不存在 placeholder_img 标签,我可以运行类似的插件。

所以问题是当你启动 jekyll 时,它会在服务器运行之前尝试构建静态文件,所以在那个时候,FastImage 无法获取图像。

尝试像这样启动 jekyll

jekyll serve --skip-initial-build

然后,只要更改任何文件,jekyll 就会成功地重新生成它并提供它。

如果在 jekyll 未运行时更改了某些文件,您可能需要触摸一些文件以触发重新生成,或者在服务器已经运行时运行 jekyll build。

于 2015-11-27T11:50:54.047 回答