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

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

 

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

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

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

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

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

 

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

 
  1. <html>

  2. <head>

  3. <title>get file input full pathtitle>

  4. <script language=""javascript"">

  5. function getFullPath(obj)

  6. {

  7. if(obj)

  8. {

  9. if (window.navigator.userAgent.indexOf("MSIE")>=1) //ie

  10. {

  11. obj.();

  12. return document.ion.createRange().text;

  13. }

  14. else if(window.navigator.userAgent.indexOf("Firefox")>=1) //firefox

  15. {

  16. if(obj.files)

  17. {

  18. return obj.files.item(0).getAsDataURL();

  19. }

  20. return obj.value;

  21. }

  22. return obj.value;

  23. }

  24. }

  25. </script>

  26. <head>

  27. <body>

  28. <input type="file" οnchange="document.getElementById(""img"").src=getFullPath(this);" />

  29. <img id="img" />

  30. </body>

  31. </html>

 

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

 

例子二

 
  1. <script type="text/javascript">

  2. //FX获取文件路径方法

  3. function readFileFirefox(fileBrowser) {

  4. try {

  5. netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");

  6. }

  7. catch (e) {

  8. alert('无法访问本地文件,由于浏览器安全设置。为了克服这一点,请按照下列步骤操作:(1)在地址栏输入"about:config";(2) 右键点击并选择 New->Boolean; (3) 输入"signed.applets.codebase_principal_support" (不含引号)作为一个新的首选项的名称;(4) 点击OK并试着重新加载文件');

  9. return;

  10. }

  11. var fileName=fileBrowser.value; //这一步就能得到客户端完整路径。下面的是否判断的太复杂,还有下面得到ie的也很复杂。

  12. var file = Components.classes["@mozilla.org/file/local;1"]

  13. .createInstance(Components.interfaces.nsILocalFile);

  14. try {

  15. // Back slashes for windows

  16. file.initWithPath( fileName.replace(///g, "\\") );

  17. }

  18. catch(e) {

  19. if (e.result!=Components.results.NS_ERROR_FILE_UNRECOGNIZED_PATH) throw e;

  20. alert("File '" + fileName + "' cannot be loaded: relative paths are not allowed. Please provide an absolute path to this file.");

  21. return;

  22. }

  23. if ( file.exists() == false ) {

  24. alert("File '" + fileName + "' not found.");

  25. return;

  26. }

  27. return file.path;

  28. }

  29. //根据不同浏览器获取路径

  30. function getvl(){

  31. //判断浏览器

  32. var Sys = {};

  33. var ua = navigator.userAgent.toLowerCase();

  34. var s;

  35. (s = ua.match(/msie ([d.]+)/)) ? Sys.ie = s[1] :

  36. (s = ua.match(/firefox/([d.]+)/)) ? Sys.firefox = s[1] :

  37. (s = ua.match(/chrome/([d.]+)/)) ? Sys.chrome = s[1] :

  38. (s = ua.match(/opera.([d.]+)/)) ? Sys.opera = s[1] :

  39. (s = ua.match(/version/([d.]+).*safari/)) ? Sys.safari = s[1] : 0;

  40. var file_url="";

  41. if(Sys.ie<="6.0"){

  42. //ie5.5,ie6.0

  43. file_url = document.getElementById("file").value;

  44. }else if(Sys.ie>="7.0"){

  45. //ie7,ie8

  46. var file = document.getElementById("file");

  47. file.select();

  48. file_url = document.selection.createRange().text;

  49. }else if(Sys.firefox){

  50. //fx

  51. //file_url = document.getElementById("file").files[0].getAsDataURL();//获取的路径为FF识别的加密字符串

  52. file_url = readFileFirefox(document.getElementById("file"));

  53. }

  54. //alert(file_url);

  55. document.getElementById("text").innerHTML="获取文件域完整路径为:"+file_url;

  56. }

  57. </script>

  58. <h1>JS获取文件域完整路径的方法,兼容不同浏览器</h1>

  59. <div id="text" style="color:#f00;"></div>

  60. <input type="file" id="file" />

  61. <input name="" type="button" value="获取" onClick="getvl();">