js上传图片预览的实现方法


Posted in Javascript onMay 09, 2017

本文实例为大家分享了js上传图片预览的方法,供大家参考,具体内容如下

<html >

<head>  
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
<title>图片上传本地预览</title>  
<style type="text/css">
#preview{width:260px;height:190px;border:1px solid #000;overflow:hidden;}
#imghead {filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image);}
</style>
<script type="text/javascript">


    //图片上传预览 IE是用了滤镜。
  function previewImage(file)
  {
   var MAXWIDTH = 260; 
   var MAXHEIGHT = 180;
   var div = document.getElementById('preview');
   if (file.files && file.files[0])
   {
    div.innerHTML ='<img id=imghead>';
    var img = document.getElementById('imghead');
    img.onload = function(){
    var rect = clacImgZoomParam(MAXWIDTH, MAXHEIGHT, img.offsetWidth, img.offsetHeight);
    img.width = rect.width;
    img.height = rect.height;
//     img.style.marginLeft = rect.left+'px';
    img.style.marginTop = rect.top+'px';
    }
    var reader = new FileReader();
    reader.onload = function(evt){img.src = evt.target.result;}
    reader.readAsDataURL(file.files[0]);
   }
   else //兼容IE
   {
   var sFilter='filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale,src="';
   file.select();
   var src = document.selection.createRange().text;
   div.innerHTML = '<img id=imghead>';
   var img = document.getElementById('imghead');
   img.filters.item('DXImageTransform.Microsoft.AlphaImageLoader').src = src;
   var rect = clacImgZoomParam(MAXWIDTH, MAXHEIGHT, img.offsetWidth, img.offsetHeight);
   status =('rect:'+rect.top+','+rect.left+','+rect.width+','+rect.height);
   div.innerHTML = "<div id=divhead style='width:"+rect.width+"px;height:"+rect.height+"px;margin-top:"+rect.top+"px;"+sFilter+src+"\"'></div>";
   }
  }
  function clacImgZoomParam( maxWidth, maxHeight, width, height ){
   var param = {top:0, left:0, width:width, height:height};
   if( width>maxWidth || height>maxHeight )
   {
    rateWidth = width / maxWidth;
    rateHeight = height / maxHeight;

    if( rateWidth > rateHeight )
    {
     param.width = maxWidth;
     param.height = Math.round(height / rateWidth);
    }else
    {
     param.width = Math.round(width / rateHeight);
     param.height = maxHeight;
    }
   }

   param.left = Math.round((maxWidth - param.width) / 2);
   param.top = Math.round((maxHeight - param.height) / 2);
   return param;
  }
</script>  
</head>  
<body>
<div id="preview">
 <img id="imghead" width=100 height=100 border=0 src='<%=request.getContextPath()%>/images/defaul.jpg'>
</div>


 <input type="file" onchange="previewImage(this)" />  
</body>  
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery中replaceWith()方法用法实例
Dec 25 Javascript
JS实现点击按钮控制Div变宽、增高及调整背景色的方法
Aug 05 Javascript
javascript数组去重小结
Mar 07 Javascript
基于javascript html5实现3D翻书特效
Mar 14 Javascript
JavaScript学习小结之使用canvas画“哆啦A梦”时钟
Jul 24 Javascript
在js中实现邮箱格式的验证方法(推荐)
Oct 24 Javascript
Vue系列:通过vue-router如何传递参数示例
Jan 16 Javascript
详解Angular 中 ngOnInit 和 constructor 使用场景
Jun 22 Javascript
Js利用Canvas实现图片压缩功能
Sep 13 Javascript
javascript使用正则实现去掉字符串前面的所有0
Jul 23 Javascript
基于Bootstrap下拉框插件bootstrap-select使用方法详解
Aug 07 Javascript
微信小程序跨页面传递data数据方法解析
Dec 13 Javascript
react开发中如何使用require.ensure加载es6风格的组件
May 09 #Javascript
Vue2单一事件管理组件通信
May 09 #Javascript
react-router实现按需加载
May 09 #Javascript
BootStrap表单时间选择器详解
May 09 #Javascript
兼容浏览器的js事件绑定函数(详解)
May 09 #Javascript
JS触摸与手势事件详解
May 09 #Javascript
Angualrjs 表单验证的两种方式(失去焦点验证和点击提交验证)
May 09 #Javascript
You might like
session 的生命周期是多长
2006/10/09 PHP
windows xp下安装pear
2006/12/02 PHP
PHP 程序员应该使用的10个组件
2009/10/31 PHP
php中JSON的使用与转换
2015/01/14 PHP
在Mac OS上编译安装Nginx+PHP+MariaDB开发环境的教程
2016/02/23 PHP
支付宝服务窗API接口开发php版本
2016/07/20 PHP
浅谈Yii乐观锁的使用及原理
2017/07/25 PHP
PHP基于迭代实现文件夹复制、删除、查看大小等操作的方法
2017/08/11 PHP
js操作Xml(向服务器发送Xml,处理服务器返回的Xml)(IE下有效)
2009/01/30 Javascript
左右悬浮可分组的网站QQ在线客服代码(可谓经典)
2012/12/21 Javascript
jquery库文件略庞大用纯js替换jquery的方法
2014/08/12 Javascript
JS+CSS实现仿支付宝菜单选中效果代码
2015/09/25 Javascript
使用Web Uploader实现多文件上传
2016/06/08 Javascript
基于zepto.js简单实现上传图片
2016/06/21 Javascript
微信小程序 闭包写法详细介绍
2016/12/14 Javascript
基于javaScript的this指向总结
2017/07/22 Javascript
让你彻底掌握es6 Promise的八段代码
2017/07/26 Javascript
Node.js中使用mongoose操作mongodb数据库的方法
2017/09/12 Javascript
用vue封装插件并发布到npm的方法步骤
2017/10/18 Javascript
深入研究React中setState源码
2017/11/17 Javascript
vue-cli 3 全局过滤器的实例代码详解
2019/06/03 Javascript
node.js实现带进度条的多文件上传
2020/03/27 Javascript
详解Django中的权限和组以及消息
2015/07/23 Python
K-means聚类算法介绍与利用python实现的代码示例
2017/11/13 Python
python中ASCII码字符与int之间的转换方法
2018/07/09 Python
Python loguru日志库之高效输出控制台日志和日志记录
2020/03/07 Python
CSS3等相关属性制作分页导航实现代码
2012/12/24 HTML / CSS
日本快乐生活方式购物网站:Shop Japan
2018/07/17 全球购物
俄罗斯茶和咖啡网上商店:Tea.ru
2021/01/26 全球购物
英国著名的美容护肤和护发产品购物网站:Lookfantastic
2020/11/23 全球购物
日期和时间问题
2015/01/04 面试题
工程资料员岗位职责
2014/03/10 职场文书
2014物价局群众路线对照检查材料思想汇报
2014/09/21 职场文书
大学社团活动总结怎么写
2019/06/21 职场文书
《雪域豹影》读后感:父爱的伟大
2019/12/23 职场文书
MyBatis XPathParser解析器使用范例详解
2022/07/15 Java/Android