第一种方式
  1. <script type="text/javascript">
  2. function setImagePreview() {
  3. var docObj = document.getElementById("ctl00_ContentMain_file_head");
  4. var fileName = docObj.value;
  5. if (!fileName.match(/.jpg|.gif|.png|.bmp/i)) {
  6. alert('您上传的图片格式不正确,请重新选择!');
  7. return false;
  8. }
  9. var imgObjPreview = document.getElementById("preview");
  10. if (docObj.files && docObj.files[0]) {
  11. //火狐下,直接设img属性
  12. imgObjPreview.style.display = 'block';
  13. imgObjPreview.style.width = '63px';
  14. imgObjPreview.style.height = '63px';
  15. //imgObjPreview.src = docObj.files[0].getAsDataURL();
  16. if (window.navigator.userAgent.indexOf("Chrome") >= 1 || window.navigator.userAgent.indexOf("Safari") >= 1) {
  17. imgObjPreview.src = window.webkitURL.createObjectURL(docObj.files[0]);
  18. }
  19. else {
  20. imgObjPreview.src = window.URL.createObjectURL(docObj.files[0]);
  21. }
  22. } else {
  23. //IE下,使用滤镜
  24. docObj.select();
  25. docObj.blur();
  26. var imgSrc = document.selection.createRange().text;
  27. var localImagId = document.getElementById("localImag");
  28. //必须设置初始大小
  29. localImagId.style.width = "63px";
  30. localImagId.style.height = "63px";
  31. //图片异常的捕捉,防止用户修改后缀来伪造图片
  32. try {
  33. localImagId.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
  34. localImagId.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;
  35. } catch (e) {
  36. alert("您上传的图片格式不正确,请重新选择!");
  37. return false;
  38. }
  39. imgObjPreview.style.display = 'none';
  40. document.selection.empty();
  41. }
  42. return true;
  43. }
  44. </script>



<div id="localImag"><img id="preview" width="-1" height="-1" style="display:none" /></div> 
<asp:FileUpload ID="file_head" runat="server" onchange="javascript:setImagePreview();" />

第二种方式

  1. function setImagePreview(a,b) {
  2. var url ='';
  3. if (navigator.userAgent.indexOf("MSIE")>=1) { // IE
  4. url = document.getElementById(a).value;
  5. } else if(navigator.userAgent.indexOf("Firefox")>0) { // Firefox
  6. url = window.URL.createObjectURL(document.getElementById(a).files.item(0));
  7. } else if(navigator.userAgent.indexOf("Chrome")>0) { // Chrome
  8. url = window.URL.createObjectURL(document.getElementById(a).files.item(0));
  9. }
  10. var imgPre = document.getElementById(b);
  11. imgPre.src = url;
  12. }

a = fileid
b=imgid

浏览器 本地预览图片 window.url.createobjecturl的更多相关文章

  1. 本地预览图片html和js例子

    本地预览图片html和js例子,直接上代码吧. <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" ...

  2. FileReader本地预览图片

    <body> <p><label>请选择一个图像文件:</label><input type="file" id=" ...

  3. js 本地预览图片和得到图片实际大小

    //填充预览图片 function adpter(file, upfile) { var imgName = new Date().getTime() + file.name.substr(file. ...

  4. js在本地预览图片

    移动web <body> <form enctype="multipart/form-data" name="form1"> 上传文件: ...

  5. H5实现本地预览图片

    我们使用H5可以很容易的实现图片上传前对其进行预览的功能 Html代码如下: <!DOCTYPE html> <html lang="en"> <he ...

  6. js本地预览图片

    废话不说  直接上代码 <script type="text/javascript" src="http://code.jquery.com/jquery-late ...

  7. Thinkphp5+plupload图片上传功能,支持实时预览图片。

    今天和大家分享一个国外的图片上传插件,这个插件支持分片上传大文件.其中著名的七牛云平台的jssdk就使用了puupload插件,可见这个插件还是相当牛叉的. 这个插件不仅仅支持图片上传,还支持大多数文 ...

  8. js图片前端预览之 filereader 和 window.URL.createObjectURL

    //preview img : filereader方式 document.getElementById('imgFile').onchange = var ele = document.getEle ...

  9. 微信开发中使用微信JSSDK和使用URL.createObjectURL上传预览图片的不同处理对比

    在做微信公众号或者企业微信开发业务应用的时候,我们常常会涉及到图片预览.上传等的处理,往往业务需求不止一张图片,因此相对来说,需要考虑的全面一些,用户还需要对图片进行预览和相应的处理,在开始的时候我使 ...

随机推荐

  1. linux文本文件按列合并

    http://blog.163.com/liang8421@126/blog/static/894819572009386653912/ 我想把文本文件file1 和文本文件 file2按照相应的行合 ...

  2. oc 第五天(内存管理)

    OC的重点: 内存管理 1 基本原理     OC的内存回收机制是和JAVA的自动回收机制是不同的,它有两种模式,或者准确的说是同 一种模式的两种不同体现,下面简单总结下. 1手动内存回收       ...

  3. Gerrit代码审核服务器搭建全过程

    Gerrit代码审核服务器搭建全过程 转载请标明出处:http://blog.csdn.net/ganshuyu/article/details/8978614 环境:Ubuntu12.xx 1.建立 ...

  4. IOS 预处理语句

    程序中的源代码计算机是无法识别的,需要将写好的代码转成0.1二进制代码,计算机才能识别.将源代码转成二进制代码的需要经过两步,编译和链接.编译是通过编译器将每个文件的代码都转为二进制代码,在这个过程中 ...

  5. Linux磁盘扩容

    Linux磁盘扩容 fdisk -l # 查看硬盘信息 lvextend -L +1G /dev/mapper/vg00-lvroot 或者 lvextend -l +%FREE /dev/mappe ...

  6. JavaScript计算两个日期的时间差

    /** * * @param startTime * @param endTime * @param diffType * @returns {Number|number} * @constructo ...

  7. (剑指Offer)面试题42:左旋转字符串

    题目: 字符串的左旋转操作是把字符串前面的若干字符转移到字符串的后面.请定义一个函数实现字符串左旋转操作的功能, 比如:输入字符串"abcdefg"和数字2,该函数将返回左旋转2位 ...

  8. TabHost随着输入法软键盘出现而上浮的问题

    解决办法: 在androidMenifest.xml中的TabHost对应的activity中添加如下代码: android:screenOrientation="portrait" ...

  9. QtGui.QPen

    The QtGui.QPen is an elementary graphics object. It is used to draw lines, curves and outlines of re ...

  10. AP*更新供应商地点

    --更新供应商地点 PROCEDURE update_vendor_site(p_init_msg_list IN VARCHAR2 DEFAULT fnd_api.g_false, x_return ...