DOM变化
<input type="file">
HTML5支持文件对话框标签 <input type="file" /> , 并提供了属性如multiple , accept以及 webkitdirectory 等 .
NW.js应用更好的扩展了文件输入框 . 但考虑到安全性 , NW.js扩展的属性只能在Node框架中启用 . 参考安全查看Node和普通框架的区别 .
fileinput.value
用途:包含本地文件的原路径
例如,您可以使用Node.js API读取用户选择的文件路径:
// 获取选择文件的原路径
var fileinput = document.querySelector('input[type=file]');
var path = fileinput.value;
// 使用Node.js的API读取文件
var fs = nw.require('fs');
fs.readFile(path, 'utf8', function(err, txt) {
if (err) {
console.error(err);
return;
}
console.log(txt);
});fileitem.path
用途:获取
files中选择的每个文件原路径
HTML5提供了 files属性来返回在 <input>标签中选择的所有文件。
NW.js则为 files提供了一个额外属性 fileitem.path获取 files中选择的每个文件原路径,
var fileinput = document.querySelector('input[type=file]');
var files = fileinput.files;
for (var i = 0; i < files.length; ++i) {
console.log(files[i].path);
}标签属性: nwdirectory
属性:
nwdirectory属性类似于webkitdirectory, 但返回值为路径 , 而不是文件对象
<input type="file" nwdirectory>标签属性: nwsaveas
属性:
nwsaveas属性可打开让可输入文件路径的'另存为'对话框. 该方式不同于默认的文件选择标签
<input type="file" nwsaveas>该属性还支持指定默认的存储文件名称:
<input type="file" nwsaveas="filename.txt">标签属性: nwworkingdir
属性:当激活元素时,
nwworkingdir属性可令文件对话框将在给定目录中打开
例如,在 /home/path/中打开文件对话框:
<input type="file" nwworkingdir="/home/path/">事件: oncancel
触发:取消对话框时
<iframe>
NW.js扩展了 <iframe>标签使应用开发更加简单 , 可以绕过沙箱限制以及同源策略等跨域问题 .
参考webview标签中的 <webview>标签 .
标签属性: nwdisable
属性:使框架和自框架为正常框架
注意,该属性不能阻止页面中正常框架访问父页面以及体层框架 . 但仍然能够访问Node.js的API . 该属性通常与 nwfaketop属性一同使用 .
标签属性: nwfaketop
属性:阻止框架中页面访问
window.parent或window.top
框架自己拥有 window对象 , 其子框架也会受到影响
该属性通常与 nwdisable一同使用
标签属性: nwUserAgent
属性:框架和自框架加载页面时重写
user-agent属性
更多细节,请参考user-agent配置