Chrome扩展程序可将数据保存到本地文件

时间:2016-06-20 21:25:57

标签: javascript google-chrome-extension html5-filesystem

我正在制作Chrome扩展程序,它会在浏览器中保存每个操作,例如new_tab,new_window,switch_tab,close_tab ......但我想在csv文件中本地存储信息。我尝试过很多指南和教程,但仍然无法正常工作。 首先,我只想将测试字符串保存到本地文件中,这个文件是否可见?我计划从大约20人那里获取这些数据。

在清单中:

{
  "manifest_version": 2,

  "name": "Getting started example",
  "description": "This is testing description",
  "version": "1.0",

  "browser_action": {
    "default_icon": "icon.png",
    "default_popup": "popup.html",
    "default_title": "Click here!"
  },
  "permissions": [
    "activeTab",
    "tabs",
    ]
}

在popup.html中导入了javascript <script type="text/javascript" src="popup.js"></script>

并在popup.js中是这样的:

window.onload = function() {
var filesystem = null;
window.requestFileSystem = window.requestFileSystem || window.webkitRequestFileSystem;

window.requestFileSystem(window.PERSISTENT, 5*1024*1024 , onInitFs, errorHandler);

  function onInitFs() {
  filesystem = fs;

  filesystem.root.getFile('treehouse.txt', {create: true}, function(fileEntry) {

  fileEntry.createWriter(function(fileWriter) {

  fileWriter.onwriteend = function(e) {
   console.log("write done");
  };

  fileWriter.onerror = function(e) {
    console.log("write error");
  };

  var contentBlob = new Blob(['JUST OWN TEXT FOR TESTING!'], {type: 'text/plain'});

  fileWriter.write(contentBlob);

}, errorHandler);
}, errorHandler);

}


function errorHandler(e) {
  var msg = '';

  switch (e.message) {
    case FileError.QUOTA_EXCEEDED_ERR:
      msg = 'QUOTA_EXCEEDED_ERR';
      break;
    case FileError.NOT_FOUND_ERR:
      msg = 'NOT_FOUND_ERR';
      break;
    case FileError.SECURITY_ERR:
      msg = 'SECURITY_ERR';
      break;
    case FileError.INVALID_MODIFICATION_ERR:
      msg = 'INVALID_MODIFICATION_ERR';
      break;
    case FileError.INVALID_STATE_ERR:
      msg = 'INVALID_STATE_ERR';
      break;
    default:
      msg = 'Unknown Error';
      break;
  };
  console.log('Error: ' + msg);
}
}

Uncaught ReferenceError: fs is not defined行的控制台filesystem = fs;上收到错误 没有创建文件或我没找到它。我假设root是某个地方C:/或C:/ Windows

有人可以帮忙修复代码吗?或者一些有用的建议?

1 个答案:

答案 0 :(得分:0)

您需要将onInitFs()更改为onInitFs(fs),因为window.requestFileSystem函数会将您的新文件系统句柄作为回调的参数传递给您。