刚接触到一个内联图片的概念,内联图片即使把图片文件编码成base64 看下面代码即是内联问题
可以减少http的请求,缺点是不能跨域缓存!
<img src=http://www.shancun.net/skin/default/image/nopic.gif alt=http://www.shancun.net/skin/default/image/nopic.gifhttp://www.shancun.net/skin/default/image/nopic.gif>
然后在线如何把图片转化成base64
如果只依靠单纯的javascript是有权限问题的 js不允许操作本地的file文件或文件夹 为了安全问题
现在html5来了 百度了下有不少资料 中文的也不少 给下w3c的文档 http://www.w3.org/TR/FileAPI/
现在我们用html5的file api里的 readAsDataURL函数 这是一个把文件转化成base64编码的
<!DOCTYPE html PUBLIC http://www.shancun.net/skin/default/image/nopic.gif-//W3C//DTD XHTML 1.0 Transitional//ENhttp://www.shancun.net/skin/default/image/nopic.gif http://www.shancun.net/skin/default/image/nopic.gifhttp://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtdhttp://www.shancun.net/skin/default/image/nopic.gif>
<html xmlns=http://www.shancun.net/skin/default/image/nopic.gifhttp://www.w3.org/1999/xhtmlhttp://www.shancun.net/skin/default/image/nopic.gif>
<head>
<meta http-equiv=http://www.shancun.net/skin/default/image/nopic.gifContent-Typehttp://www.shancun.net/skin/default/image/nopic.gif content=http://www.shancun.net/skin/default/image/nopic.giftext/html; charset=utf-8http://www.shancun.net/skin/default/image/nopic.gif />
<title>简单的html5 File测试 for pic2base64</title>
<style>
</style>
<script>
window.onload = function(){
var input = document.getElementById(http://www.shancun.net/skin/default/image/nopic.gifdemo_inputhttp://www.shancun.net/skin/default/image/nopic.gif);
var result= document.getElementById(http://www.shancun.net/skin/default/image/nopic.gifresulthttp://www.shancun.net/skin/default/image/nopic.gif);
var img_area = document.getElementById(http://www.shancun.net/skin/default/image/nopic.gifimg_areahttp://www.shancun.net/skin/default/image/nopic.gif);
if ( typeof(FileReader) === 'undefined' ){
result.innerHTML = http://www.shancun.net/skin/default/image/nopic.gif抱歉,你的浏览器不支持 FileReader,请使用现代浏览器操作!http://www.shancun.net/skin/default/image/nopic.gif;
input.setAttribute( 'disabled','disabled' );
} else {
input.addEventListener( 'change',readFile,false );}
}
function readFile(){
var file = this.files[0];
//这里我们判断下类型如果不是图片就返回 去掉就可以上传任意文件
if(!/image/w+/.test(file.type)){
alert(http://www.shancun.net/skin/default/image/nopic.gif请确保文件为图像类型http://www.shancun.net/skin/default/image/nopic.gif);
return false;
}
var reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = function(e){
result.innerHTML = '<img src=http://www.shancun.net/skin/default/image/nopic.gif'+this.result+'http://www.shancun.net/skin/default/image/nopic.gif alt=http://www.shancun.net/skin/default/image/nopic.gifhttp://www.shancun.net/skin/default/image/nopic.gif/>';
img_area.innerHTML = '<div class=http://www.shancun.net/skin/default/image/nopic.gifsitetiphttp://www.shancun.net/skin/default/image/nopic.gif>图片img标签展示:</div><img src=http://www.shancun.net/skin/default/image/nopic.gif'+this.result+'http://www.shancun.net/skin/default/image/nopic.gif alt=http://www.shancun.net/skin/default/image/nopic.gifhttp://www.shancun.net/skin/default/image/nopic.gif/>';
}
}
</script>
</head>
<body>
<input type=http://www.shancun.net/skin/default/image/nopic.giffilehttp://www.shancun.net/skin/default/image/nopic.gif value=http://www.shancun.net/skin/default/image/nopic.gifsdgsdghttp://www.shancun.net/skin/default/image/nopic.gif id=http://www.shancun.net/skin/default/image/nopic.gifdemo_inputhttp://www.shancun.net/skin/default/image/nopic.gif />
<textarea id=http://www.shancun.net/skin/default/image/nopic.gifresulthttp://www.shancun.net/skin/default/image/nopic.gif rows=30 cols=300></textarea>
<p id=http://www.shancun.net/skin/default/image/nopic.gifimg_areahttp://www.shancun.net/skin/default/image/nopic.gif></p>
</body>
</html>