function getPath()
{
  //判断浏览器
  var Sys = {};
  var obj = document.getElementById("headImg");
  var viewer = document.getElementById("viewImg");
  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;
  var path="";
  if(Sys.ie<="6.0"){
    //ie5.5,ie6.0
    viewer.src = obj.value;
  }else if(Sys.ie>="7.0"){
    //ie7,ie8
    obj.select();
    //加上这一句防止报告安全问题
    obj.blur();
    viewer.src = document.selection.createRange().text;
  }else if(Sys.firefox){
    if (obj.files) {
        var accept = ["image/png","image/jpeg","image/jpg","image/gif"];
        if (accept.indexOf(obj.files[0].type) > -1) {
            var reader = new FileReader();
            reader.readAsDataURL(obj.files[0]);
            //延迟一会等待文件读取完毕
            var t = setTimeout(function(){
            viewer.src = reader.result;
            clearTimeout(t);
            },100)
        }
    }
    else
    {
        viewer.src = obj.value;
    }
  }else if(Sys.chrome){
    viewer.src = obj.value;
  }
}

<form>
<input type="file" id="headImg" />
<input id="btnOk" type="button" value="ok" onclick="getPath()"/>
<img src="http://blog.163.com/zhchf_52@yeah/blog/" alt="view" id="viewImg" />
</form>

由于IE9不能实时的显示图片,所以采用滤镜的方法:
<style type="text/css">
#viewImg2{ /* 该对象用于在IE下显示预览图片 */    
 filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);    
 width:150px;
 height:150px;
 display:none;
 overflow: hidden;
}    
#viewImg{ /* 该对象只用来在IE下获得图片的原始尺寸,无其它用途 */    
  filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=image);   
  width:150px;
  height:150px;
  display:none;
  overflow:hidden;
}
</style>

<form id="uploadForm" action="" method="post" enctype="multipart/form-data">
<input type="file" id="headImg" onchange="view()" name="headImg"/>
<input type="submit" value="保存" id="btnSave" disabled="disabled" />
<p class="lineH30 color6">建议使用正方形的图片,支持JPG、GIF、PNG格式,100K以内。</p>
<div id="viewImg2"></div>
<img src="http://blog.163.com/zhchf_52@yeah/blog/" alt="" id="viewImg"/>
<script type="text/javascript">
    //file文件控件,viewer 图像查看,accept支持的文件格式的mimetype数组
    function viewImage(file, viewer, viewer2, btn, accept) {
        //判断浏览器
        var Sys = {};
        if (file && viewer) {
            if (!viewer2) {
                viewer2 = viewer;
            }
            if (!accept || accept.length == 0) {
                accept = ["image/png", "image/jpeg", "image/jpg", "image/gif", "image/bmp"];
            }
            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;
            var path = "";
            if (Sys.ie) {
                viewer.style.display = "none";
                if (Sys.ie <= "6.0") {
                    //ie5.5,ie6.0
                    path = file.value;

}
                else if (Sys.ie >= "7.0") {
                    //ie7,ie8
                    file.select();
                    //加上这一句防止报告安全问题
                    file.blur();
                    path = document.selection.createRange().text;
                }
                v = isValidImage(path, accept);
                if (v) {
                    viewer2.style.display = "block";
                    if (viewer2.filters) {
                        viewer2.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = path;
                    }
                    else {
                        viewer2.src = path;
                    }
                }
            }
            else if (Sys.firefox) {
                viewer2.style.display = "none";
                viewer.style.display = "block";
                if (file.files && file.files.length > 0) {
                    if (accept.indexOf(file.files[0].type) > -1) {
                        var reader = new FileReader();
                        reader.readAsDataURL(file.files[0]);
                        //延迟一会等待文件读取完毕
                        var t = setTimeout(function () {
                            viewer.src = reader.result;
                            clearTimeout(t);
                        }, 100);
                        v = true;
                    }
                }
                else {
                    path = file.value;
                    v = isValidImage(path, accept);
                    if (v) {
                        viewer.src = file.value;
                    }
                }
            }
            else {
                viewer2.style.display = "none";
                viewer.style.display = "block";
                path = file.value;
                v = isValidImage(path, accept);
                if (v) {
                    viewer.src = file.value;
                }
            }

if (v) {
                if (btn) {
                    $("#" + btn).removeAttr("disabled");
                }
            }
            else {
                viewer.src="http://blog.163.com/zhchf_52@yeah/blog/";
                $("#btnSave").attr("disabled", "disabled");
            }
        }
    }
    //是否为有效的图片格式
    function isValidImage(path, accept) {
        var v = false;
        if (path
        && path.length > 0
        && path.indexOf(".") > 0
        && accept
        && accept.length > 0) {
            var idx = path.lastIndexOf(".") + 1;
            if (path.length > idx) {
                var ext = path.substr(idx).toLowerCase();
                for (var i = 0; i < accept.length; i++) {
                    if (accept[i].indexOf("/" + ext) > 0) {
                        v = true;
                        break;
                    }
                }
            }
        }
        return v;
    }

function autoSizePreview(objPre, originalWidth, originalHeight) {
        var zoomParam = clacImgZoomParam(150, 150, originalWidth, originalHeight);
        objPre.style.width = zoomParam.width + 'px';
        objPre.style.height = zoomParam.height + 'px';
        objPre.style.marginTop = zoomParam.top + 'px';
        objPre.style.marginLeft = zoomParam.left + 'px';
    }

function clacImgZoomParam(maxWidth, maxHeight, width, height) {
        var param = { width: width, height: height, top: 0, left: 0 };

if (width > maxWidth || height > maxHeight) {
            rateWidth = width / maxWidth;
            rateHeight = height / maxHeight;

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

param.left = (maxWidth - param.width) / 2;
        param.top = (maxHeight - param.height) / 2;

return param;
    }

function view() {
        viewImage(document.getElementById("headImg"),
        document.getElementById("viewImg"),
        document.getElementById("viewImg2"),
        "btnSave",
        accept);
    }
</script>
</form>

js获取input file完整路径的方法的更多相关文章

  1. js 获取input file路径改变图像地址

    html代码 <img id="newImage" alt="100x100" src="__PUBLIC__/img/1.jpg" ...

  2. js获取input file路径改变图像地址

    版权声明:好歹是我写的或者总结的或者抄的,总待给我个名份吧~ https://blog.csdn.net/sangjinchao/article/details/52250318 html代码 < ...

  3. js获取 input file 图片缩略图

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. js 获取 input file 文件 附给 image src

    var a=document.querySelector('input[type=file]'); a.onchange = function (e) { //var reader = new Fil ...

  5. js获取input file文件二进制码

    <html> <body> <img id="image"src=""/> <br/> <input ty ...

  6. js 获取input type="file" 选择的文件大小、文件名称、上次修改时间、类型等信息

    文件名的传递 ---全路径获取 $('#file').change(function(){ $('#em').text($('#file').val()); }); 文件名的传递 ---只获取文件名 ...

  7. js清空input file的值

    原文:js清空input file的值 在做选择本地图片上传的功能时遇到一个问题,第一次点file按钮选择图片完成会触发onchange事件,获取文件后动态在界面上创建img标签展示,但把创建的img ...

  8. javascript中外部js文件取得自身完整路径得办法

    原文:javascript中外部js文件取得自身完整路径得办法 有时候我们需要引入一个外部js文件,这个js文件又需要用到自己的路径或者是所在的目录,别问怎么又这么变态的需求,开发做久了各种奇葩需求也 ...

  9. JS获取fileupload文件全路径

    来自:http://hi.baidu.com/libos88/item/c61ab8bae472afe34ec7fdfb 最近在写个小网站,用到了fileupload控件来上传文件.因为程序的某些需要 ...

随机推荐

  1. 从linux telnet到exchange邮件server来測试发送邮件

    我们在Linux下,能够通过telnet邮件server的25port(一般smtp邮件server都是这个),来測试是否能发送邮件. 前提是先得把DNS配好,或者/etc/hosts文件制定好邮件s ...

  2. 使用CSS3 Media Queries实现网页自适应(转)

    当今银屏分辨率从 320px (iPhone)到 2560px (大屏显示器)或者更大.人们也不再仅仅用台式机来浏览网页,现在有手机,平板电脑等等.所以传统的固定宽度设计形式将不再是个最佳选择,网页设 ...

  3. 浅谈web前端就业的学习路线

    初级前端 主要学习三个部分:HTML,CSS,JavaScript 一.html + css部分: 这部分特别简单,到网上搜资料,书籍视频非常多.css中盒子模型,流动,block,inline,层叠 ...

  4. 标准C++的vector使用

    原文:http://blog.csdn.net/pandy1110/article/details/5963908 C++内置的数组支持容器的机制,但是它不支持容器抽象的语义.要解决此问题我们自己实现 ...

  5. SQL Server 2012 Enterprise Edition安装过程详解(包含每一步设置的含义)

    一.启动安装程序,点击“安装”选项卡,选择“全新SQL Server独立安装或向现有安装添加功能”.(首次安装数据库系统或向现有数据库系统添加功能,均选择此选项) 二.随后,安装程序进行“安装程序支持 ...

  6. 安装rvm命令行工具

    rvm是一个命令行工具,可以提供一个便捷的多版本ruby环境的管理和切换. https://rvm.io/ 如果你打算学习ruby/rails, rvm是必不可少的工具之一. 这里所有的命令都是再用户 ...

  7. 跳跃表 C#

               虽然avl树和红黑树在数据搜索和排序方面都是有效的数据结构,但是都显得特别麻烦,跳跃表就显得特别简单,虽然简单 不影响他性能,在平均情况下,其插入.删除.查找数据时间复杂度都是O ...

  8. python基础教程

    转自:http://www.cnblogs.com/vamei/archive/2012/09/13/2682778.html Python快速教程 作者:Vamei 出处:http://www.cn ...

  9. C语言基础04

    什么叫数组呢?我们的第一反应是很多数组合在一起就是数组,字面意思,当然不仅仅是数字,字符也是可以的. 数组属于构造类型 .指相同类型的若干变量组织起来. 类型说明符 数组名 [常量表达式] int   ...

  10. 正则语言(转的 大额_skylar )

    备注:正则表达式真的很头疼,收集起来,用起来很方便的. 常用的元字符 . 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符 \d 匹配数字 \b 匹配单词的开始或 ...