用UltraEdit读取gif的16进制,然后我试图在html中img的src直接赋值为码流,没有作用

解决方案 »

  1.   

    FF可以直接支持BASE64的编码的图片格式,IE支持Data URI 和 MHTML格式。
      

  2.   

    IE比较麻烦,如果是火狐的话或其他标准浏览器可以用date协议
      

  3.   

    在火狐下你可以使用这段代码显示一图片
    <img src="">
      

  4.   

    貌似没有很完善的解决方案。
    <img alt="Red Star" src="">这个能在FF下显示,但是IE不行。
    以下链接是我搜索到的相关内容:
    http://bbs.blueidea.com/thread-2680136-1-893.html
    http://bbs.blueidea.com/viewthread.php?tid=2669499
    http://www.dynamicdrive.com/forums/archive/index.php/t-7647.html
      

  5.   

    想到了一个折中办法,可以单独写一个后台程序为IE6、IE7
    和其他不支持data协议的浏览器来服务器,它接受图片代码
    以流形式返回图片
    <img src="data:image/png;....."
         onerror="ImageDecoder.jsp?code=encodeURI(this.src);">
      

  6.   

    打错了几个字
    <img src="data:image/png;....."
         onerror="this.src='ImageDecoder.jsp?code='+encodeURI(this.src);"/>
      

  7.   

    这样增加了服务器的压力,用data形式就是为了减少资源的请求!
      

  8.   

    基本用法 data:[<MIME-type>][;charset="<encoding>"][;base64],<data>16进制的时候如下设置即可
    <img src="data:image/gif,%47%49%46%38%39" />IE 从8.0版本才开始支持data这个标识符,且只允许目标最大32K 所以如果你的IE看不到,你的版本有点低下面这个是可以看效果的小图片 
    <img src="data:image/png;base64,
    iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAABlBMVEUAAAD/
    //+l2Z/dAAAAM0lEQVR4nGP4/5/h/1+G/58ZDrAz3D/McH8yw83NDDeNGe4U
    g9C9zwz3gVLMDA/A6P9/AFGGFyjOXZtQAAAAAElFTkSuQmCC" />
      

  9.   


    我知道这样是需要增加一次请求,但我认为还是值得的。如果你放弃
    使用Data协议图片都要请求一次服务器,不管是什么浏览器。
    用了这种方法之后至少IE8、FireFox、Opera、Safrai可以不用请求了。
    至于那个编码的负担可以通过程序优化解决掉。因为那个图片的是你用
    程序生成的,所以你一定知道那个图片在什么位置。所以最后你的程序
    可以优化成下面的样子<img src="data:image/png;....." 
         imageid="" errorTime="0"     onerror="if(this.errorTime++==0){this.src='ImageDecoder.jsp?imageid='+encodeURI(this.imageid);}"/>或者更高效一些
    <img src="data:image/png;....." 
         path="/images/a.png" 
         errorTime="0" 
         onerror="if(this.errorTime++==0){this.src=this.path}"/>
    用哪种做法取决于你的图片在后台是怎样存放的
      

  10.   

    改进的方案:http://topic.csdn.net/u/20100127/14/a961df9a-34a1-44f1-9f9a-c10a4d168736.html