【发布时间】:2016-02-16 20:26:20
【问题描述】:
我编写了一个运行良好的 HTML 应用程序。这些是以 .hta 结尾的文件,只能使用 Internet Explorer 打开。在应用程序中,我使用了一个具有属性名称的对象作为数据库的键值。由于这是 Windows 和 Microsoft,我决定转换为 DAO。多年来,我在 DAO 方面做了很多工作,但总是使用 VB、VBA 或 .net 语法,而不是 Javascript。
使用 Javascript,如果我将记录集中的字段命名为记录集对象的属性,即使用句点,它们是可访问的,但是我必须以这种方式进行硬编码,并且它不是动态的。我想要做的是遍历记录集对象的 Fields 集合并获取字段名称。我无法让它工作。它一直说“无法从对象的空实例中获取名称”。
在下面的 db_update 函数中,我传递了一个属性名称与记录集中的字段名称匹配的对象。该例程很灵活,允许我避免对字段名称进行硬编码。我正在这样做,但想更改为这种格式,它不会工作。我无法在任何地方使用带有 Javascript 的 DAO 找到任何信息。例程中的注释说“它在这条线上失败”。 Count 属性以正确的值存在于 Fields 集合中,因此存在 Fields 集合。
function setup() {
db_engine = new ActiveXObject("DAO.DBEngine.36");
fso = new ActiveXObject("Scripting.FileSystemObject");
.....
if (fso.FileExists(mdb)) fso.DeleteFile(mdb);
db_db = db_engine.CreateDatabase(mdb,";LANGID=0x0409;CP=1252;COUNTRY=0");
var table = db_db.CreateTableDef("file"), ord=1;
db_create_field(table,"id",4,4,ord,false,false);
ord++;
db_create_field(table,"path",10,255,ord,false,false);
ord++;
db_create_field(table,"local",3,2,ord,false,false);
ord++;
.....
}
function db_create_field(table,name,type,length,ordinal,required,allow_zl) {
var fld = table.CreateField(name,type,length);
fld.Attributes = 1;
fld.OrdinalPosition = ordinal;
fld.ValidationRule = "";
fld.ValidationText = "";
fld.Required = required ? -1 : 0;
try {
fld.AllowZeroLength = allow_zl ? -1 : 0;
}
catch(e) {
}
table.Fields.Append(fld);
}
function db_update(wad) {
var rst=db_db.OpenRecordset("SELECT * FROM file WHERE path='"+wad.path+"'",2);
if (rst.EOF) {
rst.AddNew();
rst.id = file_id++;
rst.path = wad.path;
}
else {
rst.edit();
}
var count=rst.Fields.Count, name;
for (var j=0;j<count;j++) {
name = rst.Fields[j].Name; // IT FAILS ON THIS LINE FOR "NAME"
if (wad.hasOwnProperty(name)) rst.Fields[j] = wad[name];
}
rst.Update();
rst.Close();
}
【问题讨论】:
-
也许我必须实例化一个枚举器对象。这是迭代文件系统对象的文件和文件夹集合所需要的。也许这同样适用于这里。我会试试的。
标签: javascript dao hta