js/jquery 获取本地文件的文件路劲 获取input框中type=‘file’ 中的文件路径(转载)
js/jquery 获取本地文件的文件路劲 获取input框中type=‘file’ 中的文件路径
版权声明:本文为博主原创文章,未经博主允许不得转载。
分为两部分,自己去判断浏览器的类型,然后调用不同函数,一定要引入jQuery,上面是我的Jquery的路径
在IE低版本中可以直接获得文件路径,不过在高版本和firefox和chrome中是不允许的。那是个漏洞
这样就能实现不用上传就可以实现图片的实时预览了
1.IE内核的部分,IE10 没问题,别的没试,
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- <script type="text/javascript" src="软件工程概论/软件工程实验原型/js/jquery-1.8.3.min.js"></script>
- <script type="text/javascript">
- var imgurl = "";
- function getImgURL(node) {
- var imgURL = "";
- var file = null;
- if(node.files && node.files[0] ){
- file = node.files[0];
- }else if(node.files && node.files.item(0)) {
- file = node.files.item(0);
- }
- //这种获取方式支持IE10
- node.select();
- imgURL = document.selection.createRange().text;
- alert(imgURL);
- var textHtml = "<img src='"+imgURL+"'/>"; //创建img标签用于显示图片
- alert(textHtml);
- $(".mark").after(textHtml);
- return imgURL;
- }
- </script>
- </head>
- <body>
- <div style="width:200px; height:210px; border:1px solid red;" id="show">
- <div class="mark"></div>
- </div>
- <br>
- <input type="file" value="上传文件" onchange="getImgURL(this)">
- </body>
- </html>
2.火狐和chrome浏览器,其实这个获得的文件路径不是我们能看懂的,它是一个对象,不过浏览器能解析,可能出于浏览器的安全考虑吧,本来不能显示文件路径
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- <script type="text/javascript" src="软件工程概论/软件工程实验原型/js/jquery-1.8.3.min.js"></script>
- <script type="text/javascript">
- var imgurl = "";
- function getImgURL(node) {
- var imgURL = "";
- try{
- var file = null;
- if(node.files && node.files[0] ){
- file = node.files[0];
- }else if(node.files && node.files.item(0)) {
- file = node.files.item(0);
- }
- //Firefox 因安全性问题已无法直接通过input[file].value 获取完整的文件路径
- try{
- //Firefox7.0
- imgURL = file.getAsDataURL();
- //alert("//Firefox7.0"+imgRUL);
- }catch(e){
- //Firefox8.0以上
- imgRUL = window.URL.createObjectURL(file);
- //alert("//Firefox8.0以上"+imgRUL);
- }
- }catch(e){ //这里不知道怎么处理了,如果是遨游的话会报这个异常
- //支持html5的浏览器,比如高版本的firefox、chrome、ie10
- if (node.files && node.files[0]) {
- var reader = new FileReader();
- reader.onload = function (e) {
- imgURL = e.target.result;
- };
- reader.readAsDataURL(node.files[0]);
- }
- }
- //imgurl = imgURL;
- creatImg(imgRUL);
- return imgURL;
- }
- function creatImg(imgRUL){ //根据指定URL创建一个Img对象
- var textHtml = "<img src='"+imgRUL+"'/>";
- $(".mark").after(textHtml);
- }
- </script>
- </head>
- <body>
- <div style="width:90px; height:110px; overflow:hidden; border:1px solid red;" id="show">
- <div class="mark"></div>
- </div>
- <br>
- <input type="file" value="上传文件" onchange="getImgURL(this)">
- </body>
- </html>
3.其余的浏览器。我没有测试,不过国内的其他如360和遨游,等都有两种模式,一种是IE内核,这(1)中可以运行,第二种内核没找到好方法
4.推荐出处
https://developer.mozilla.org/zh-CN/docs/DOM
js/jquery 获取本地文件的文件路劲 获取input框中type=‘file’ 中的文件路径(转载)的更多相关文章
- input type=file 上传文件样式美化(转载)
input type=file 上传文件样式美化 来源:https://www.jianshu.com/p/6390595e5a36 在做input文本上传时,由于html原生的上传按钮比较丑,需要对 ...
- vue项目内嵌入到app input type=file 坑(文件上传插件)
w问题描述: 我用vue-cli完成的一个移动端项目,内嵌到app当中,用原生的input type=file 来完成文件上传.在安卓下没有问题但是在苹果手机 上传第二次手机就会发生白屏 并无缘无故跳 ...
- javaWeb - 2 — ajax、json — 最后附:后台获取前端中的input type = "file"中的信息 — 更新完毕
1.ajax是什么? 面向百度百科一下就知道了,这里就简单提炼一下 Ajax即Asynchronous Javascript And XML(异步JavaScript和XML).当然其实我们学的应该叫 ...
- uedit修改文件上传路劲,支持api文件接口
首先修改一个东西ueditor/ueditor.config.js serverUrl: URL + "php/controller.php" 原来 serverUrl: &quo ...
- jquery判断 input type="file"上传文件是否为空
要想获取type="file"的input内容,用var file = $("id").val();肯定是不行的,下面是代码: html上传按钮为: <i ...
- 如何获取input框type=file选中的文件对象(FileReader)
$("input[type='file']").change(function() { var file = this.files[0]; if (window.FileReade ...
- <input type="file">上传文件并添加路径到数据库
注:这里是用的mvc所以没法用控件 html代码 <form method="post" enctype="multipart/form-data"> ...
- 上传文件时文件类型限制 <input id="File1" type="file" accept=""/>
在做项目项目中经常需要上传文件,类型也就那几种.虽然在js中加了上传文件类型的限制,但是为了减少因为用户选择不当而造成的反复检验.可以在input标签上加上accept属性.这种限制只是优化了选择文件 ...
- HTML <input type="file">上传文件——结合asp.net的一个文件上传示例
HTML的代码:(关键是要在form里设置enctype="multipart/form-data",这样才能在提交表单时,将文件以二进制流的形式传输到服务器) 一. <fo ...
随机推荐
- js,h5页面判断客户端是ios还是安卓
$(function(){ var u = navigator.userAgent, app = navigator.appVersion; var isAndroid = u.indexOf('An ...
- Do not mutate vuex store state outside mutation handlers.
组件代码: selectItem(item,index) { this.selectPlay({ list: this.songs, index }) }, ...mapActions([ 'sele ...
- iframe优缺点
优点:重载页面时不需要重载整个页面,只需要重载页面中的一个框架页(减少了数据的传输,加快了网页下载速度)
- 【TOJ 5103】Electric Fence(皮克定理)
描述 In this problem, `lattice points' in the plane are points with integer coordinates. In order to c ...
- Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法
在使用了 RTKLIB开源包自带的 rtkplot.exe后,知道了它所具有的功能,就想着如何模仿它做出一个 demo.一开始看的是之前下载的 2.4.2版本的 RTKLIB,里面是使用 Delphi ...
- ansible-palybook剧本
1 ansible基础知识部分补充 1.1 ansible软件特点: · 可以实现批量管理 · 可以实现批量部署 · ad-hoc(批量执行命令)---针对临时性的操作 ansible clsn -m ...
- Linux常用文档操作命令--1
1.查看目录下的文档 a) ls(list):查看目录下的所有文档或者文档的信息. 命令行:ls [-a][-A] [-f][-F][-h][-l][-r][-R][-S][-t] 目录名称 //注 ...
- vue入门——基本概念
1. 挂载点,模板,实例的关系? 首先附上一个基本demo: <!DOCTYPE html> <html lang="en"> <head> & ...
- C调用约定__cdecl、__stdcall、__fastcall、__pascal分析
参考原文地址:https://www.cnblogs.com/yenyuloong/p/9626658.html C/C++ 中不同的函数调用规则会生成不同的机器代码,产生不同的微观效果,接下来让我们 ...
- 【ssh服务配置】
根据项目需求,搭建好拓扑图如下: 第一种验证方式:给予密码和用户名登录 Ssh server配置: 首先在服务器上创建一个rsa加密算法的秘钥对: 对ssh服务进行开启: 创建用户的虚拟终端登录界面: ...