如何在HTML文件中重复使用base64图像

Dev*_*ate 8 html javascript html5 base64 static

我有一个HTML文件,可以移植分发给客户端.它有一个文件索引.我想要每个文档的PDF或Word图标,但我不想重复base64字符串30次,如果我可以避免它.我该怎么做?Javascript没问题,但我的目标是简单性和可移植性.

rya*_*sh7 10

尝试使用CSS类

img.word-icon {
  content: url();
  width: 32px;  
  height: 32px;
}
Run Code Online (Sandbox Code Playgroud)
<html>
  <body>  
    <img class="word-icon">foo
    <img class="word-icon">bar
    <img class="word-icon">
  </body>
</html>
Run Code Online (Sandbox Code Playgroud)

  • 哦,现在这很棒.我没想过CSS.谢谢! (2认同)

Mar*_*rga 5

使用CSS的另一个答案给出了正确的想法,但它并不与所有浏览器兼容。contentCSS 的属性仅允许在伪元素::before和中使用::afterimg具有content属性的类的标签为空。浏览器没有义务显示它。Chrome仍然显示(错误地)。

要使此功能适用于所有浏览器,请::before在空跨度上使用例如:

span.word-icon::before {
  content: url();
}
Run Code Online (Sandbox Code Playgroud)
<html>
  <body>  
    <p><span class="word-icon"></span>Paragraph with icon.</p>
  </body>
</html>
Run Code Online (Sandbox Code Playgroud)

您也可以将其直接附加到p::before


tan*_*ius 5

您可以使用 CSS 变量。

\n\n

<head>页面的 部分中,命名并定义变量以及使用它的类:

\n\n
:root {\n    --img-123: url(data:null;base64,iVBORw\xe2\x80\xa6\xe2\x80\xa6\xe2\x80\xa6); /* your image data here */\n}\n\n.img-123 {\n    background-blend-mode: normal;\n    background-clip: content-box;\n    background-position: 50% 50%;\n    background-color: rgba(0,0,0,0);\n    background-image:var(--img-123);\n    background-size: 100% 100%;\n    background-origin: content-box;\n    background-repeat: no-repeat;\n}\n
Run Code Online (Sandbox Code Playgroud)\n\n

<body>页面的部分中,通过元素样式部分或 CSS 类重复使用图像。SVG 数据创建一个透明图像,通过该图像可以看到内容。

\n\n
<img \n  class="img-123" \n  src="data:image/svg+xml,&lt;svg xmlns=&quot;http://www.w3.org/2000/svg&quot; width=&quot;16&quot; height=&quot;16&quot;&gt;&lt;rect fill-opacity=&quot;0&quot;/&gt;&lt;/svg&gt;"\n>\n
Run Code Online (Sandbox Code Playgroud)\n\n

我在开源 Firefox/Chrome 扩展SingleFile的输出中观察到了这种技术。可能有一些方法可以简化 CSS 并避免使用 SVG。

\n

  • 我是 SingleFile 的作者。SingleFile 中 SVG 的目的是在不更改 CSS 的情况下指定图像的大小。因此,我确认如果使用 CSS 设置图像的宽度和高度对您来说不是问题,您可以避免使用 SVG。 (4认同)