Reputation: 10912
What is the correct way, in a Markdown document, to reference images that are stored in the /asset
folder, so they can be rendered locally (Visual Studio Code) but also deployed in a Jekyll site?
Right now I include my images like this:
data:image/s3,"s3://crabby-images/df63e/df63e11b296723a6e1866644d8364c289094e049" alt="alt text"
This works only when the site is rendered with Jekyll and if site.url
is correctly set, which means that _config.yml
has to be changed depending on the location the Jekyll project is deployed (on root of domain vs. in subfolder).
But this does not work at all if I render the document in e.g. Visual Studio Code. There I haev this option:
data:image/s3,"s3://crabby-images/b5db4/b5db4beb4377e159f28db0c2d56e30c030ab2392" alt="alt text"
which will of course not work when deployed with Jekyll in a subfolder.
Or I can use a fully relative reference:
data:image/s3,"s3://crabby-images/eb116/eb11615b548360d8febc7fe4229125a868b08944" alt="alt text"
which is very impractical as image paths depend on where I have my content files. Moving a file from one folder to another changes the image URL.
Is there a way to make both Jekyl and local rendering (e.g. Visual Studio Code) work?
Upvotes: 2
Views: 2947
Reputation: 23982
The following way misses the baseurl
, i.e. it doesn't handle subdirectories:
data:image/s3,"s3://crabby-images/df63e/df63e11b296723a6e1866644d8364c289094e049" alt="alt text"
To fix that, have baseurl
in _config.yml
and use it in your links:
data:image/s3,"s3://crabby-images/e175a/e175ab274968c4a28f37b4f7b25cf8c48bd1a170" alt="alt text"
Even better, use absolute_url
that will include url
and baseurl
generating full paths:
data:image/s3,"s3://crabby-images/6a553/6a553deb96a957f1421226b366d7d4da7125ec1e" alt="alt text"
As discussed in comments, the above solution won't work in VSCode but having images with relative paths does.
So putting the mages in each post/collection folder and loading them with relative paths should make VSCode able to render images in each file - while also keeping Jekyll happy and render the image as it should.
Upvotes: 3