图片浏览上传兼容所有浏览器

代码使用js原生完成。就是为了移植方便。由于时间原因尚有限制文件大小与限制图片格式没有完成

/*
*author : 矛盾距离
*date : 2014/4/18 9:52
*topic : 图片上传浏览
*description : 这是原生实现的直接使用就可
*/
var ImagePreview = function(file, img, options) {
	this.file = file;
	this.img = img;
	this._data = null; //图片数据
	var opt = this._setOptions(options);
	this.ratio = opt.ratio;
	this.maxWidth = opt.maxWidth;
	this.maxHeight = opt.maxHeight;
	this.maxSize = opt.maxSize;
	this.filterFormat = opt.filterFormat; //允许的图片格式,不同的数据格式请用"|"隔开
	this._preload= null; //预加载对象用于获取数据
}
ImagePreview.prototype = {
	_setOptions : function(options){
		var opt = {
			ratio : 0, //自定义比例
			maxWidth : 0, //缩略图宽度
			maxHeight : 0, //缩略图高度
			maxSize : 50, //默认限制图像大小单位KB
			filterFormat : "jpg|jpeg|png|gif"
		};
		return this._extend(opt, options || {});
	},
	_extend : function(target, source){
		for(var p in source) {
			if (source.hasOwnProperty(p))
			{
				target[p] = source[p];
			}
		}
		return target;
	},
	//客户端调用
	preview : function() {
		if (!this._checkimg())
		{
			return;
		}
		var Sys = this._userAgent();
		//首先判断ie,减少代码执行。按照使用量排序
		if ((Sys.ie) && (Sys.ie == 7.0 || Sys.ie == 8.0))
		{
			this._data = this._filterData();
			this._filterProcess();
		}else if(Sys.firefox || Sys.chrome)  
		{
			this._data = this._commonData();
			this._commonProcess();
		}else{
			this._data = this._simpleData();
			this._commonProcess();
		}
	},

	//滤镜显示
	_filterProcess : function() {
		var dataPath = this._data;
		this._filterPreload();
		var preload = this._preload;
		try{
			preload.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = dataPath;
		}catch(e){
			alert("滤镜错误");
		}
		this.img.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale',src=\"" + dataPath + "\")";
		var alpha = "";
		this._imgShow(alpha, preload.offsetWidth, preload.offsetHeight);

	},

	//google与 firefox 显示方式
	_commonProcess : function() {
		var dataPath = this._data;
		var preload = this._preload = new Image();
		var oThis = this;
		var onload = function(){
				oThis._imgShow(dataPath, this.width, this.height);
		};
		preload.onload = onload;
		preload.onerror = function() {oThis._error("加载过程中发生错误")};
		this._preload.src = dataPath;
	},
	
	//远程获取处理
	_remoteProcess : function() {
		//暂不实现暂时不需要
	},

	_imgShow : function(src, width, height){
		var img = this.img;
		var style = img.style;
		var ratio = Math.max( 0, this.ratio ) || Math.min( 1,
				Math.max( 0, this.maxWidth ) / width  || 1,
				Math.max( 0, this.maxHeight ) / height || 1
			);
		//设置预览尺寸
		style.width = Math.round( width * ratio ) + "px";
		style.height = Math.round( height * ratio ) + "px";
		//设置src
		img.src = src;
	},
	
	//滤镜数据获取方式ie7, ie8
	_filterData : function() {
		this.file.select();
		try{
			return document.selection.createRange().text;
		}finally{
			document.selection.empty();
		}
	},

	//一般数据获取程序(google&&firefox)
	_commonData : function() {
		//注意这里的webkitURL chrome10.0+;
		if (window.URL==undefined)
		{
			return window.webkitURL.createObjectURL(this.file.files.item(0));
		}else{
			return window.URL.createObjectURL(this.file.files.item(0));
		}
	},
	
	// 简单获取数据方式ie10 
	_simpleData : function() {
		return this.file.value;	
	},

	//设置滤镜预载图片对象用于获取图片大小
	_filterPreload : function() {
		if (!this._preload)
		{
			var preload = this._preload = document.createElement("div");
			preload.style.width = "1px";
			preload.style.height = "1px";
			preload.style.visibility = "hidden";
			preload.style.position ="absolute";
			preload.style.left = "-9999px";
			preload.style.top = "-9999px";
			preload.style.filter ="progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='image')";
			var body = document.body; 
			body.insertBefore( preload, body.childNodes[0]);
		}
	},

	//检查图片是否符合条件
	_checkimg :	function(){
			var value = this.file.value;
			var check = true;
			if ( !value ) {
				check = false; 
				alert("请先选择文件!");
			} else if ( !RegExp( "\.(?:"+this.filterFormat+")$", "i" ).test(value) ) {
				check = false; 
				alert("只能上传以下类型:" +this.filterFormat);
			} else if ( this.filterFormat.indexOf( "|" + value + "|" ) >= 0 ) {
				check = false; 
				alert("已经有相同文件!");
			}
			return check;
	},

	_error : function(err) {
		alert(err);
		return;
	},
	_userAgent : function() {
		var Sys = {};
		var ua = navigator.userAgent.toLowerCase();
		var s;
		(s = ua.match(/msie ([\d.]+)/)) ? Sys.ie = s[1] :
		(s = ua.match(/firefox\/([\d.]+)/)) ? Sys.firefox = s[1] :
		(s = ua.match(/chrome\/([\d.]+)/)) ? Sys.chrome = s[1] :
		(s = ua.match(/opera.([\d.]+)/)) ? Sys.opera = s[1] :
		(s = ua.match(/version\/([\d.]+).*safari/)) ? Sys.safari = s[1] : 0;
		return Sys;
	}
}

测试页面代码

<!doctype html>
<html lang="en">
 <head>
  <meta charset="UTF-8">
  <meta name="Generator" content="EditPlus®">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <title>Document</title>
  <script src="preview.js"></script>
 </head>
 <body>
	<img id="idImg"/>
   <form>
      请上传你的相片:<INPUT type="file" name="file" id="up">
	  <input type="submit" value="上传">
    </form>
	<script>
		var file = document.getElementById("up");
		var img = document.getElementById("idImg");
		var ip = new ImagePreview(file, img, {
			maxWidth: 200, maxHeight: 200
		});
		ip.file.onchange = function(){ ip.preview(); };
	</script>
 </body>
</html>



 

你可能感兴趣的:(js,图片上传浏览)