我正在尝试将交互式小说游戏从 inform7 移植到 javascript。很多语法很容易转换成javascript;其中一些甚至可以在转换后进行优化。但是“表格”功能在 JavaScript 中并不存在,我可以想出很多方法来模仿它。这是 inform7 表的语法:
Table of example table
column one column two column three column four
---------- ---------- ------------ ----------
---------- ---------- ------------ ---------
When Play begins:
Choose a blank row from Table of example table;
now column one entry is "text";
now column two entry is 400;
now column three entry is true
now column four entry is [non primitive]
在javascript中实现这一点的最有效方法是什么?
请记住,我计划使用严格模式,甚至不想考虑使用 3rd 方框架/库,例如 JQuery。只有最新的 ECMAScript 规范中定义的 JavaScript。
我的一些想法:
使用地图:
const tables = new Map();
// to create table
tables.set("wandering monsters", [
new Map([
["monster name","default"]
])
]);
//to get table entry
tables.get("wandering monsters")[0].get("monster name");
使用函数:
function table(name, row, key, val, entrylist){
var result;
if (table.data == undefined){
table.data = new Map();
};
switch (arguments.length) {
case 1:
result = table.data.get(name);
break;
case 2:
table.data.set(name, []);
result = table.data.get(name);
break;
case 3:
result = table.data.get(name)[row].get(key);
break;
case 4:
table.data.get(name)[row].set(key, val);
result = table.data.get(name)[row].get(key);
break;
case 5:
table.data.get(name)[row] = new Map(entrylist);
result = table.data.get(name)[row];
break;
default:
result = table.data;
};
return result;
}
我在手机上编辑