JavaScript读文件(HTML5)

在HTML5中,我们可以使用FileReader对象来读取INPUT-INPUT控件中选中的文件的内容。下面是例子:
<input type="file" id="f" />
<script>
window.οnlοad=function(){
  //获取INPUT-FILE控件对象
  var f=document.getElementById("f");
  //添加change事件,会在选择文件时候触发
  f.οnchange=function(){
    //创建一个FR对象来读文件
    var fr=new FileReader;
    //给FR对象添加一个load事件,会在读到文件时候触发
    fr.οnlοad=function(){
      //这个result属性中保存的就是文件的内容啦
      console.log(fr.result);
    };
    //读取二进制数据到一个字符串中,或者称为字节数组
    fr.readAsBinaryString(f.files[0]);
  };
};
</script>
  注意HTML5中的INPUT-FILE控件中使用的是储存文件列表的files属性,因为在HTML5中INPUT-FILE控件有个multiple属性,这是上这个属性就可以同时选择多个文件了,所以需要用拟数组来保存选中的文件列表。这个例子中没有设置multiple,这就意味着只能选择一个文件。那么我们在文件选中以后从files属性的0这个索引中取出这个文件对象。
  关于文件对象,在早期的HTML5中支持getAs*的方法,可以直接读取文件的内容,但是现在的HTML5中废弃了这些方法。需要使用专门的FileReader对象来读取文件内容。FileReader可以以不同的方式读入文件,比如上面的例子是把文件的二进制作为字符串读入,也就是ANSI编码读入。
  除了笨拙的INPUT-FILE控件外,还有另外一种灵活的文件选择方式。那就是传说中的拖拽,使用拖拽事件可以直接获取到拖拽到网页上的文件。下面是拖拽的例子:
<script>
//这个是火狐的BUG,不阻止dragover的行为就无法组织drop的行为
document.οndragοver=function(e){e.preventDefault()};
//直接在整个文档上定义拖拽事件
document.οndrοp=function(e){
  //创建FR对象,这个在上面的例子中介绍过了
  var fr=new FileReader;
  fr.οnlοad=function(){
    console.log(fr.result);
  };
  //使用FR对象以utf-8的编码读取一个文本文件
  fr.readAsText(e.dataTransfer.files[0],"utf-8");
  //阻止默认行为
  //文件拖拽会被有些浏览器解析为“打开”
  e.preventDefault();
};
</script>

  读文件就是这么简单啦,学会了读文件我们就可以利用它做很多事情。比如在客户端计算文件的MD5,这样就可以在文件上传之前和服务器的文件列表比对,以防止重复上传浪费带宽。功能的实现就是这样,具体的用途那就是项目设计师的工作了。


转载请注明:前端录»JavaScript读文件(HTML5)

<script src="http://www.wozhuye.com/index.php?m=digg&c=index&a=init&id=20-75-2"></script>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Qt WebAssembly ,由于浏览器的安全限制,不能直接访问本地文件系统。但是可以通过使用 HTML5 的 File API,将本地文件入内存,然后在 WebAssembly 进行处理。 以下是一个简单的示例代码,演示了如何从 WebAssembly 取本地文件: ```cpp #include <emscripten.h> #include <emscripten/bind.h> #include <string> #include <fstream> using namespace std; // 从本地文件取数据 string read_file(const string& filename) { ifstream file(filename, ios::binary); if (!file) { return ""; } string content((istreambuf_iterator<char>(file)), istreambuf_iterator<char>()); return content; } // 在 JavaScript 调用 read_file() 函数 EM_JS(std::string, js_read_file, (const char* filename), { return new Promise((resolve, reject) => { const xhr = new XMLHttpRequest(); xhr.open('GET', filename); xhr.responseType = 'blob'; xhr.onload = () => { if (xhr.status === 200) { const reader = new FileReader(); reader.onload = () => { resolve(reader.result); }; reader.readAsText(xhr.response); } else { reject(xhr.statusText); } }; xhr.onerror = () => { reject(xhr.statusText); }; xhr.send(); }); }); // 在 C++ 调用 js_read_file() 函数 string wasm_read_file(const string& filename) { return js_read_file(filename.c_str()); } // 将函数暴露给 JavaScript EMSCRIPTEN_BINDINGS(my_module) { emscripten::function("read_file", &wasm_read_file); } ``` 在这个示例,我们定义了一个 C++ 函数 `read_file()` 来取本地文件。然后,我们使用 `EM_JS()` 宏来定义一个名为 `js_read_file()` 的 JavaScript 函数,该函数通过 XMLHttpRequest 对象来异步加载指定的文件,并使用 FileReader 对象将文件内容取为字符串并返回。最后,我们定义了另一个 C++ 函数 `wasm_read_file()`,该函数调用 `js_read_file()` 函数并返回文件内容。最后,我们使用 `EMSCRIPTEN_BINDINGS()` 宏将 `wasm_read_file()` 函数暴露给 JavaScript。 ### 回答2: 在Qt使用WebAssembly取本地文件,可以通过以下步骤实现: 第一步,将本地文件加载到内存。可以使用Qt的QFile类读取文件内容,并将文件内容存储到一个QByteArray对象。 第二步,将取的文件内容转换为Base64编码的字符串。可以使用Qt的QByteArray的toBase64方法将文件内容转换为Base64编码的字符串。 第三步,将Base64编码的字符串传递给WebAssembly。可以使用Qt的QWebChannel类从Qt应用程序向WebAssembly应用程序传递数据。在Qt应用程序,可以创建一个QWebChannel对象,并通过调用QWebChannel的registerObject方法将一个QObject子类对象注册到QWebChannel上。在WebAssembly应用程序,可以使用JavaScript的XMLHttpRequest对象发送请求,并将Base64编码的字符串作为请求体发送给Qt应用程序。 第四步,在WebAssembly处理接收到的文件内容。在Qt应用程序,可以在已注册的QObject子类对象实现一个槽函数,用于接收来自WebAssembly的文件内容。在WebAssembly应用程序,可以使用JavaScript的XMLHttpRequest对象的onload事件处理程序来处理接收到的响应。在事件处理程序,可以将接收到的Base64编码的字符串解码,并对文件内容进行进一步处理。 通过上述步骤,可以在Qt使用WebAssembly取本地文件。注意,由于WebAssembly的沙箱限制,通常无法直接访问本地文件系统。因此,需要通过将文件内容加载到内存,并通过Base64编码传递给WebAssembly来实现本地文件取。 ### 回答3: 在Qt WebAssembly取本地文件是一个相对复杂的过程,因为WebAssembly的运行环境是基于浏览器的,并且对于安全原因,浏览器限制了WebAssembly的访问本地文件系统的能力。但是,我们可以通过一些技巧和工具来实现取本地文件的需求。 一种方法是使用WebAssembly的File System API,该API允许WebAssembly模块创建、取和写入文件。通过这个API,我们可以模拟本地文件系统的行为。但是需要注意的是,这种方法只适用于在WebAssembly模块内部模拟文件系统,而不能直接访问真实的本地文件。 另一种方法是使用emscripten工具链,该工具链可以将C/C++代码编译成可以在WebAssembly运行的JavaScript代码。通过emscripten提供的函数和工具,我们可以在JavaScript实现本地文件取操作,然后将取到的数据传递给WebAssembly模块进行处理。 具体来说,我们可以使用emscripten提供的函数`FS.readFile`来取本地文件。首先,我们需要将文件加载到JavaScript,然后使用`FS.readFile`来读取文件的内容。取到的内容可以以字符串或二进制形式传递给WebAssembly模块进行后续处理。 需要注意的是,使用emscripten进行文件取需要在编译时配置相关选项,并且在页面加载生成的JavaScript文件和WebAssembly模块。 综上所述,在Qt WebAssembly取本地文件是通过一些技巧和工具来实现的,如模拟文件系统或使用emscripten工具链。这些方法可以满足我们对于取本地文件的需求,但也需要注意安全和浏览器环境的限制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值