This demo uses gatsby-remark-images
.
Order of plugins in your gatsby-config.js matters. Please add gatsby-remark-image-attributes
after gatsby-remark-images
or any other image processing plugins!
data:image/s3,"s3://crabby-images/d393a/d393a885653854531d489f2cd8bcd19ed60667ec" alt="no attributes"
To use CSS properties like box-shadow
, add them to the title!
data:image/s3,"s3://crabby-images/6f615/6f6153c28bd3bee122c060819d66eb12f00053a8" alt="test";width=150px')
gatsby-remark-image-attributes
wraps the result of other image processing plugins, aiming to reach body
as the wrapper's offsetParent
. Your styleAttributes
will be set on that wrapper, not the <img>
.
Compare the offsetParent
s of these two images to see the difference:
This is the ribbon in the upper-right corner of this page:
data:image/s3,"s3://crabby-images/08c0d/08c0d5dedf7b66908ee2344122e02e0b47503ad6" alt="fork me on github"
This plugin generates <img>
tags and all browsers support SVG in <img>
Elements.
data:image/s3,"s3://crabby-images/aa9fa/aa9fa1933e27486c3bfb9e657029c02ed2c773be" alt="svg" brightness(1.5) drop-shadow(2px 4px 6px black)')
works data:image/s3,"s3://crabby-images/b0403/b0403b6646f508bc25c335de3f0497217d098d77" alt="gatsby" inline data:image/s3,"s3://crabby-images/4ab99/4ab99ce0752b6fd63d0c2f78b0b3d4128e20e87a" alt="gatsby", too data:image/s3,"s3://crabby-images/9b90f/9b90f1c66c47655d1d3e71de724337eb30fbd944" alt="gatsby"
works
inline
, too
* or data:image/s3,"s3://crabby-images/dd1a5/dd1a5c1aa14220821a99b442821a811611ce60d6" alt="gatsby"
* in data:image/s3,"s3://crabby-images/8100d/8100dfe287e2e475465f2cdbbe836e7852070d3e" alt="gatsby"
* lists data:image/s3,"s3://crabby-images/66d32/66d329e11675a7b66cbb7567d7d43110f246496f" alt="gatsby"
Set the plugin's dataAttributes
option to true
to enable data- attributes.
data:image/s3,"s3://crabby-images/4a659/4a659cfd46500c5404566c98ad107eae4402e7cf" alt="gatsby"
'Inspect' this Element ⇒
to see
data-some
and data-another
on it!
Unlike the styleAttributes, dataAttributes are always set on the <img>
Element, never on the wrapper.
Titles without key=value;
pairs behave according to the CommonMark standard; even when they start with a #
.
data:image/s3,"s3://crabby-images/ab9c0/ab9c0bb3790107b0face8e31853dd08558b461e6" alt="no attributes"
To add an actual title=""
attribute to the <img>
, add an image attribute with key: title
.
data:image/s3,"s3://crabby-images/a9a36/a9a364729512004f3e274c87bb7daf1cc3140861" alt="title from attribute"