js中获取file控件的完整路径实例

时间:2025-03-01 07:32:07

本文章来给大家介绍一个js中获取file控件的完整路径实例,有需要了解的朋友可以参考参考。

(""my-file"").files办法用于获取到用户所选择的文件的凑集,一般景象下都是选择单一文件(貌似FireFox如许做是支撑多文件选择的,不过没有试过,读者可以本身去测验测验),item数组可以获得此中的某一个文件,然后我们就可以应用 nsIDOMFile所供给的属性和办法了。它包含2个属性和3个办法:


fileName:用于获取到用户所选文件的名称,这和直接取value值所获得的成果一样。

fileSize:获得用户所选文件的大小。

getAsBinary():获得用户所选文件的二进制数据。

getAsDataURL():获得用户所选文件的路径,该路径被加密了,今朝只能在FireFox中应用。

getAsText():获得用户所选文件的指定字符编码的文本。


有一点须要申明,办法getAsDataURL()可以取得用户所选文件的本地路径,然则这个路径的字符串文本被FireFox加密了,并且这段密文只能被FireFox辨认,其它的浏览器不克不及辨认,也就是说我将被加密后的路径直接赋值给一个img标签的src属性,在FireFox中是可以直接显示出的,而在IE中却不可

<html>
    <head>
        <title>get file input full pathtitle>
    <script language=""javascript"">
        function getFullPath(obj)
        {
            if(obj)
            {
                if (("MSIE")>=1)    //ie
                {
                    obj.();
                    return ().text;
                }
                else if(("Firefox")>=1)             //firefox
                {
                    if()
                    {
                        return (0).getAsDataURL();
                    }
                    return ;
                }
                return ;
            }
        }
    </script> 
    <head>
    <body>
        <input type="file" οnchange="(""img"").src=getFullPath(this);" />
    <img  />
    </body>
</html>

上面实例在ie8中无法获取哦,下面我再给大家介绍一款可以兼容ie6,ie7,ie8中的解决办法,大家可参考。


例子二

<script type="text/javascript"> 
//FX获取文件路径方法 
function readFileFirefox(fileBrowser) { 
try { 
("UniversalXPConnect"); 
} 
catch (e) { 
alert('无法访问本地文件,由于浏览器安全设置。为了克服这一点,请按照下列步骤操作:(1)在地址栏输入"about:config";(2) 右键点击并选择 New->Boolean; (3) 输入".codebase_principal_support" (不含引号)作为一个新的首选项的名称;(4) 点击OK并试着重新加载文件'); 
return; 
} 
var fileName=; //这一步就能得到客户端完整路径。下面的是否判断的太复杂,还有下面得到ie的也很复杂。 
var file = ["@/file/local;1"] 
.createInstance(); 
try { 
// Back slashes for windows 
( (///g, "\\") ); 
} 
catch(e) { 
if (!=.NS_ERROR_FILE_UNRECOGNIZED_PATH) throw e; 
alert("File '" + fileName + "' cannot be loaded: relative paths are not allowed. Please provide an absolute path to this file."); 
return; 
} 
if ( () == false ) { 
alert("File '" + fileName + "' not found."); 
return; 
} 
return ; 
} 
//根据不同浏览器获取路径 
function getvl(){ 
//判断浏览器 
var Sys = {}; 
var ua = (); 
var s; 
(s = (/msie ([d.]+)/)) ?  = s[1] : 
(s = (/firefox/([d.]+)/)) ?  = s[1] : 
(s = (/chrome/([d.]+)/)) ?  = s[1] : 
(s = (/opera.([d.]+)/)) ?  = s[1] : 
(s = (/version/([d.]+).*safari/)) ?  = s[1] : 0; 
var file_url=""; 
if(<="6.0"){ 
//ie5.5,ie6.0 
file_url = ("file").value; 
}else if(>="7.0"){ 
//ie7,ie8 
var file = ("file"); 
(); 
file_url = ().text; 
}else if(){ 
//fx 
//file_url = ("file").files[0].getAsDataURL();//获取的路径为FF识别的加密字符串 
file_url = readFileFirefox(("file")); 
} 
//alert(file_url); 
("text").innerHTML="获取文件域完整路径为:"+file_url; 
} 
</script> 
<h1>JS获取文件域完整路径的方法,兼容不同浏览器</h1> 
<div  style="color:#f00;"></div> 
<input type="file"  /> 
<input name="" type="button" value="获取" onClick="getvl();">
原文链接: http:///wy/js-ajax/

相关文章