• Blob API及问题记录


    接上一篇<js创建下载文件>, 记录核心部分 Blob 的API, >>传送门 , 同时说下使用过程中碰到的一个问题.

    先说问题:

    用Blob创建后缀为.sql的文件, 内容是包含中文的文本, 结果生成的文本打开后中文部分显示乱码. 尝试加了type后,还是没有改变. 后来想到会不会是因为.sql的mime类型问题, 于是先换成了application/stram的类型, 发现问题依旧.  后来换了个思路, type不变, 取巧把后缀换成了.txt, 结果问题就好了. 因为手上事情比较多, 苦恼之下只能先采取这个方法. 哪位朋友如果有更好的方法欢迎留言告诉我, 先谢谢.

    <script>
        downloadFile("创建菜单SQL脚本.txt", response);
    
        function downloadFile(fileName, content) {
            var aLink = document.createElement('a');
            var blob = new Blob([content], { type: "text/plain" });
            var evt = document.createEvent("HTMLEvents");
            // initEvent 不加后两个参数在FF下会报错, 感谢 Barret Lee 的反馈
            evt.initEvent("click", false, false);
            aLink.download = fileName;
            aLink.href = URL.createObjectURL(blob);
            aLink.dispatchEvent(evt);
        }
    </script>

    Blob API:

    一个Blob对象就是一个包含有只读原始数据的类文件对象。Blob对象中的数据并不一定得是JavaScript中的原生形式。File接口基于Blob,继承了Blob的功能,并且扩展支持了用户计算机上的本地文件。

    创建Blob对象的方法有几种,可以调用Blob构造函数,还可以使用一个已有Blob对象上的slice()方法切出另一个Blob对象,还可以调用canvas对象上的toBlob方法。

    注: 需要注意的是,一些浏览器上的slice()方法仍带有前缀:Firefox 12之前的版本上为blob.mozSlice(),Safari上为blob.webkitSlice()
    注: 一些浏览器提供了BlobBuilder接口,但并不是所有的浏览器都支持BlobBuilder,而且现有的BlobBuilder实现都是带前缀的。更主要的是BlobBuilder已经被废弃,你应该尽可能的使用Blob构造函数来代替。

    属性Edit

    属性名     类型 描述
    size        unsigned long long Blob对象中所包含数据的大小只读。
    type DOMString 一个字符串,表明该Blob对象所包含数据的MIME类型。如果类型未知,则该值为空字符串。只读。

    构造函数Edit

    Blob Blob(
      [optional] Array parts,
      [optional] BlobPropertyBag properties
    );
    参数
    parts
    一个数组,包含了将要添加到Blob对象中的数据。数组元素可以是任意多个的ArrayBufferArrayBufferView (typed array), Blob,或者 DOMString对象。
    properties
    一个对象,设置Blob对象的一些属性。查看BlobPropertyBag一节。

    方法Edit

    slice()

    返回一个新的Blob对象,包含了源Blob对象中指定范围内的数据

    Blob slice(
      optional long long start,
      optional long long end,
      optional DOMString contentType
    );

    参数

    start可选
    开始索引,可以为负数,语法类似于数组的slice方法。默认值为0。
    end可选
    结束索引,可以为负数,语法类似于数组的slice方法。默认值为最后一个索引
    contentType可选
    新的Blob对象的MIME类型,这个值将会成为新的Blob对象的type属性的值,默认为一个空字符串

    返回值

    一个新的Blob对象,包含了源Blob对象中指定范围内的数据

    注意

    如果start参数的值比源Blob对象的size属性的值还大,则返回的Blob对象的size值为0,也就是不包含任何数据。

    BlobPropertyBagEdit

    一个包含有两个属性typeendings的对象。

    type
    设置该Blob对象的type属性
    endings(已废弃)
    对应于BlobBuilder.append()方法的endings参数。该参数的值可以是"transparent"或者"native"。

    Blob构造函数用法举例Edit

    下面的代码:

    var aFileParts = ['<a id="a"><b id="b">hey!</b></a>'];
    var oMyBlob = new Blob(aFileParts, { "type" : "text/xml" }); // the blob

    等价于:

    var oBuilder = new BlobBuilder();
    var aFileParts = ["<a id="a"><b id="b">hey!</b></a>"];
    oBuilder.append(aFileParts[0]);
    var oMyBlob = oBuilder.getBlob("text/xml"); // the blob

    BlobBuilder接口提供了另外一种创建Blob对象的方式,但该方式现在已经废弃,所以不应该再使用了。

    例子:使用类型数组和Blob对象创建一个对象URLEdit

    var typedArray = GetTheTypedArraySomehow();
    var blob = new Blob([typedArray], {type: "application/octet-binary"}); // 传入一个合适的MIME类型
    var url = URL.createObjectURL(blob);
    // 会产生一个类似blob:d3958f5c-0777-0845-9dcf-2cb28783acaf这样的URL字符串
    // 你可以像使用一个普通URL那样使用它,比如用在img.src上。

    浏览器兼容性Edit

    FeatureChromeFirefox (Gecko)Internet ExplorerOperaSafari (WebKit)
    Basic support 5 4 10 11.10 5.1
    slice()

    21
    10 webkit

    13
    5 moz
    10 12 5.1 (534.29) webkit
    Blob() constructor 20 13.0 (13.0) 10 12.10 6 (536.10)

    注意:关于slice()的实现

    slice()方法一开始使用length来作为第二个参数,表示需要向新的Blob对象拷贝多少个字节。如果你指定的参数值start + length的值超过了源Blob对象的长度,则返回的Blob对象包含了从start索引到源Blob对象结束索引处的所有数据

    这个版本的slice()实现于Firefox 4WebKit,以及 Opera 11.10中。可是,由于这个语法和我们常用的Array.slice()以及String.slice()语法不同,所以已被废弃。Gecko和WebKit目前支持的是新版的slice语法。

    从Gecko 13.0 (Firefox 13.0 / Thunderbird 13.0 / SeaMonkey 2.10)和Chrome 21开始,slice()去掉了前缀。

    Gecko备注

    在Gecko 12.0 (Firefox 12.0 / Thunderbird 12.0 / SeaMonkey 2.9)之前,slice()方法有个bug,就是参数startend的值不能超出64位无符号数字范围,现已修复。

    相关链接Edit

  • 相关阅读:
    C++Builder中的异常传递
    lpc1343 usb isp not work in linux and mac
    玩玩Hiweed linux 2.0
    有关 stringWithString 和 initWithString
    Windows mobile 中获取内存使用情况
    玩玩xubuntu 8.10
    升级我的ipaq hx2110到Windows Mobile 6.0
    面试技巧 from IBM
    常用Sql语句
    c#的事件机制示例代码: 猫> 老鼠, 主人
  • 原文地址:https://www.cnblogs.com/jiyang2008/p/5485697.html
Copyright © 2020-2023  润新知