用css和javascript动态生成图像

时间:2013-08-06 16:40:24

标签: javascript css twitter-bootstrap

我在twitter bootstrap的轮播示例中看到,container marketing img和featurette img是动态生成的。

我是css,javascript和twitter bootstrap的新手,有人可以解释一下吗?我很想知道它是如何完成的,所以我可以改变它来生成我自己的图像,谢谢!

这里是javascript(我想是的......它在holder.js):

var settings = {
    domain: "holder.js",
    images: "img",
    bgnodes: ".holderjs",
    themes: {
        "gray": {
            background: "#eee",
            foreground: "#aaa",
            size: 12
        },
        "social": {
            background: "#3a5a97",
            foreground: "#fff",
            size: 12
        },
        "industrial": {
            background: "#434A52",
            foreground: "#C2F200",
            size: 12
        }
    },
    stylesheet: ".holderjs-fluid {font-size:16px;font-weight:bold;text-align:center;font-family:sans-serif;margin:0}"
};

这里是html部分:

  <div class="featurette">
    <img class="featurette-image img-circle pull-right" data-src="holder.js/512x512">
    <h2 class="featurette-heading">First featurette heading. <span class="text-muted">It'll blow your mind.</span></h2>
    <p class="lead">Donec ullamcorper nulla non metus auctor fringilla. Vestibulum id ligula porta felis euismod semper. Praesent commodo cursus magna, vel scelerisque nisl consectetur. Fusce dapibus, tellus ac cursus commodo.</p>
  </div>

查看图像时,其地址如下所示:



编辑:

谢谢大家,谢谢!这是由于你的所有答案导致我发现图像是从主题生成的:{...}在var settings

2 个答案:

答案 0 :(得分:1)

您正在处理图像数据URI,它们基本上只是文本格式的图像,并且它们不依赖于CSS或JavaScript;它实际上只是以字符格式编码的图像数据。

您可以使用各种在线工具生成它们,例如image to data uri convertor

使用它们的好处是可以将非常小的图像内联到HTML中,从而避免浏览器发出无关的HTTP请求,如果你的HTML很好,也可以使用麻烦的解决方案。请记住,他们也有自己的缺点:例如,对于大型图像,它们的效率非常低。

答案 1 :(得分:1)

这只是数据URI图像:https://developer.mozilla.org/en-US/docs/data_URIs

它们是直接以URL格式编码的图像,因此您无需从服务器请求它们。

您可以在此网站上测试将图像编译为数据 - http://dataurl.net/#dataurlmaker

Sass和Compass还有一个帮助程序,可以直接在样式表源(http://compass-style.org/reference/compass/helpers/inline-data/)中利用编码。