• 两种 js下载文件的方法(转)


    function DownURL(strRemoteURL, strLocalURL){
            try{
                var xmlHTTP = new ActiveXObject("Microsoft.XMLHTTP");
                xmlHTTP.open("Get", strRemoteURL, false);
                xmlHTTP.send();
                var adodbStream = new ActiveXObject("ADODB.Stream");
                adodbStream.Type = 1;//1=adTypeBinary 
                adodbStream.Open();
                adodbStream.write(xmlHTTP.responseBody);
                adodbStream.SaveToFile(strLocalURL, 2);
                adodbStream.Close();
                adodbStream = null;
                xmlHTTP = null;
            }
            catch (e){
                window.confirm("下载URL出错!");
            }
            //window.confirm("下载完成."); 
        }
    

    例如要下载文件的地址为:htpp://www.baidu.com/test.rar
    我们可以使用window.open("htpp://www.baidu.com/test.rar"),
    但是该方法在火狐上没有效果的,在IE浏览器上是可以的。

    如果用window.location.href="htpp://www.baidu.com/test.rar";火狐有些版本是不支持的。

    为了解决这个问题,我们可以换做另外一种方法
    我们可以写成如下样式即可以了:
    window.location="htpp://www.baidu.com/test.rar";

    2.文件的下载到本地(默认)(ie 和火狐都可以)

    function downloadFile(url) {   
            try{ 
                var elemIF = document.createElement("iframe");   
                elemIF.src = url;   
                elemIF.style.display = "none";   
                document.body.appendChild(elemIF);   
            }catch(e){ 
     
            } 
        }
    

    js触发:

    <div class="login_center"><a href="javascript:_login()"></a></div> 
      <input type="button" value="进入1" onClick = "downloadFile('http://wan.exe')">
    

    注:在HTML中,IFRAME的属性用SRC,但在JS中,只有部份浏览器支持修改SRC(读是没问题),真正通用的是要修改对应框架的href值。

    function switchIframe(){
        window.frames["frameName"].location.href="action(或你需要的名字).aspx"
            }
    
  • 相关阅读:
    html5跨域通讯之postMessage的用法
    zTree插件之多选下拉菜单代码
    css3创建一个上下线性渐变色背景的div
    zTree插件之单选下拉菜单代码
    PhoneGap中navigator.notification.confirm的用法详解
    CCS3属性之text-overflow:ellipsis;的用法和注意之处
    HTML5的自定义属性data-* 的用法解析
    HSSFWorkbook转MultipartFile InputStream转MultipartFile
    @Transactional
    synchronized volatile
  • 原文地址:https://www.cnblogs.com/ylzhang/p/6862425.html
Copyright © 2020-2023  润新知