[英]Uploading a photo to a page in Jekyll html
我有一个基本的 jekyll 目录,如下所示:
├── 404.html
├── about.markdown
├── assets
│ └── img
│ ├── mapcolor360_dbc.png
│ └── SileHuPortrait.jpg
├── _config.yml
├── favicon.ico
├── Gemfile
├── Gemfile.lock
├── group-members.html
├── _includes
│ └── footer.html
├── index.markdown
├── _layouts
├── media.md
├── openings.md
├── _posts
│ └── 2019-12-18-welcome-to-jekyll.markdown
├── publications.md
├── research.html
├── research.md
├── _sass
│ └── _variables.scss
├── _site
│ ├── 404.html
│ ├── about
│ │ └── index.html
│ ├── assets
│ │ ├── img
│ │ │ ├── mapcolor360_dbc.png
│ │ │ └── SileHuPortrait.jpg
│ │ └── style.css
│ ├── favicon.ico
│ ├── feed.xml
│ ├── group-members
│ │ └── index.html
│ ├── index.html
│ ├── jekyll
│ │ └── update
│ │ └── 2019
│ │ └── 12
│ │ └── 18
│ │ └── welcome-to-jekyll.html
│ ├── media
│ │ └── index.html
│ ├── openings
│ │ └── index.html
│ ├── publications
│ │ └── index.html
│ ├── research
│ │ └── index.html
│ └── software
│ └── index.html
└── software.md
我想使用 group-members.html 文件中的这一行将照片上传到group-members
页面:
<img src="/home/sam/Dropbox/Documents/PhD/hellenthal-group/assets/img/SileHuPortrait.jpg">
该图像肯定存在于目录中,但是当我尝试使用bundle exec jekyll serve
编译站点时
它返回错误
[2020-03-20 19:36:13] ERROR `/home/sam/Dropbox/Documents/PhD/hellenthal-group/assets/img/SileHuPortrait.jpg' not found.
图像显示为损坏。 谁能帮我解决这个问题?
根据您的目录结构,我看到SileHuPortrait.jpg
实际上位于<source>/assets/img
。
当 Jekyll构建您的站点时,假定生成的 URL 与网络服务器一起使用。 因此,当您有像/home/sam/Dropbox/Documents/..
这样的引用时,网络服务器正在寻找相对于您的目标目录(即_site
文件夹)的/home/sam/Dropbox/Documents/..
。
您看到的错误是因为物理路径/home/sam/Dropbox/Documents/PhD/hellenthal-group/_site/home/sam/Dropbox/Documents/PhD/hellenthal-group/assets/img/SileHuPortrait.jpg
没有不存在。
因此,正确的用法是:
<img src="/assets/img/SileHuPortrait.jpg">
(注意前导斜线)
以上虽然正确, baseurl:
在配置文件中设置baseurl:
时不能灵活地自动适应。
因此,最终的解决方案是使用relative_url
Liquid 过滤器:
<img src="{{ 'assets/img/SileHuPortrait.jpg' | relative_url }}">
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.