0

我正在尝试将交互式小说游戏从 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;
}

我在手机上编辑

4

0 回答 0