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的另一个答案给出了正确的想法,但它并不与所有浏览器兼容。contentCSS 的属性仅允许在伪元素::before和中使用::after。img具有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。
您可以使用 CSS 变量。
\n\n在<head>页面的 部分中,命名并定义变量以及使用它的类:
: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}\nRun Code Online (Sandbox Code Playgroud)\n\n在<body>页面的部分中,通过元素样式部分或 CSS 类重复使用图像。SVG 数据创建一个透明图像,通过该图像可以看到内容。
<img \n class="img-123" \n src="data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><rect fill-opacity="0"/></svg>"\n>\nRun Code Online (Sandbox Code Playgroud)\n\n我在开源 Firefox/Chrome 扩展SingleFile的输出中观察到了这种技术。可能有一些方法可以简化 CSS 并避免使用 SVG。
\n| 归档时间: |
|
| 查看次数: |
1987 次 |
| 最近记录: |