浏览器 控制台 JavaScript 保存数据到硬盘文件

写数据到文件 - 方法封装

/**
 * 保存数据到指定的文件
 *  利用 Blob 对象把要下载的数据转换为二进制
 *  然后利用<a>的href属性和download属性,click事件,实现数据下载。
 * @param {string} filename 要保存的文件名
 * @param {string} str 要保存的文本内容
 */
function saveStringToFile(filename, str) {

    // 创建一个 <a> 标签对象
    var linkTag = window.document.createElement("a");
    // 设置该实例的 download 和 href 属性(HTML 5 标准属性)
    linkTag.download = filename;
    linkTag.href = window.URL.createObjectURL(new Blob([str]));

    // 把刚才手动创建的 <a> 添加到 DOM 文档中
    window.document.body.appendChild(linkTag);
    linkTag.click();    // 调用点击事件
    // 移除刚才添加的子标签
    window.document.body.removeChild(linkTag);
    
}

// 调用测试(字符串可以是任意来源,比如 fetch API 获取的JSON数据)
saveStringToFile("1.txt", "沧海一声笑");

原理解析

  1. HTML 5 a标签 新属性 download

<a>标签的属性downloadhref,用法见 https://www.runoob.com/tags/tag-a.html

在这里插入图片描述
2. HTML 演示

新建test.html,内容如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>

    <a id="app">点击试试</a>
    <script>
        var linkTag = document.getElementById("app");
        var str = "沧海一声笑"; // 要保存的数据
        linkTag.href = window.URL.createObjectURL(new Blob([str]));
        linkTag.download = "2.txt";

		// linkTag.click(); // 代码调用点击事件,也可以鼠标点击后触发。
    </script>
    
</body>
</html>

点击链接后,弹出文件下载框
在这里插入图片描述
3. 应用

使用浏览器看到一些想要保存的数据,可以使用:
- fetch API 获取响应的JSON数据;
- 以上封装的方法保存数据到本地文件

Demo

雪球网-行情 https://xueqiu.com/hq
流程略,代码如下:

function saveStringToFile(filename, str) {
    var linkTag = window.document.createElement("a");
    linkTag.download = filename;
    linkTag.href = window.URL.createObjectURL(new Blob([str]));

    window.document.body.appendChild(linkTag);
    linkTag.click();
    window.document.body.removeChild(linkTag);
}

await fetch("https://xueqiu.com/service/v5/stock/screener/screen?category=CN&size=10&order=desc&order_by=follow7d&only_count=0&page=1&_=1598890471819", {
    "credentials": "include",
    "headers": {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:80.0) Gecko/20100101 Firefox/80.0",
        "Accept": "*/*",
        "Accept-Language": "en-US,en;q=0.5",
        "cache-control": "no-cache",
        "X-Requested-With": "XMLHttpRequest"
    },
    "referrer": "https://xueqiu.com/hq",
    "method": "GET",
    "mode": "cors"
})
.then(function(response) {
  return response.json();
})
.then(function(data) {
  // console.log("data", data);     // josn类型
  var str = JSON.stringify(data, null, "  ");
  var filename = "行情.json";
  saveStringToFile(filename, str);  // 把提取到的数据保存到文件
});

就可以获取到部分JSON数据。

在这里插入图片描述

  • 文件
    行情.json
{
  "data": {
    "count": 4069,
    "list": [
      {
        "pct": 1.68,
        "symbol": "SH600519",
        "current": 1786.5,
        "follow7d": 18250,
        "name": "贵州茅台",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": -0.98,
        "symbol": "SZ000651",
        "current": 54.5,
        "follow7d": 15903,
        "name": "格力电器",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": 3.33,
        "symbol": "SH600887",
        "current": 41.94,
        "follow7d": 14033,
        "name": "伊利股份",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": 1.27,
        "symbol": "SH603288",
        "current": 183.2,
        "follow7d": 13156,
        "name": "海天味业",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": -2.83,
        "symbol": "SZ002352",
        "current": 85.1,
        "follow7d": 12627,
        "name": "顺丰控股",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": -1.63,
        "symbol": "SH601318",
        "current": 76.62,
        "follow7d": 9714,
        "name": "中国平安",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": -1.98,
        "symbol": "SH600036",
        "current": 37.69,
        "follow7d": 9505,
        "name": "招商银行",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": -0.21,
        "symbol": "SZ000858",
        "current": 240,
        "follow7d": 8548,
        "name": "五粮液",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": -1.31,
        "symbol": "SZ000568",
        "current": 149.5,
        "follow7d": 8166,
        "name": "泸州老窖",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      },
      {
        "pct": -2.56,
        "symbol": "SZ000895",
        "current": 63.5,
        "follow7d": 8080,
        "name": "双汇发展",
        "type": 11,
        "tick_size": 0.01,
        "has_follow": false
      }
    ]
  },
  "error_code": 0,
  "error_description": ""
}

以上测试过程,仅供学习参考。

MDN Links

前端基础(HTML,CSS,JavaScript)这块有什么疑问,可以直接百度MDN xxx,基本都会有结果。

以下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值