我的方法是在屏幕上绘制一些控件,现在我希望这个方法将是一个API并使其更加动态,以便为用户提供决定他想在屏幕上绘制哪个控件的能力。 我想要提供一些json结构,但不确定它是否更好然后对象...,任何建议
e.g。
withSection1 true
withSection2 false
withSecttion3 false
withSection4 true
.....
但默认情况下,如果用户想要绘制所有数据而不是提供所有数据(部分),则添加一些参数。所以我不确定如何构建它。
更新
假设我使用json作为部分 如果用户希望通过deafult绘制所有控件
,我应该如何将defualt放入方法签名中{
"withSection1": 'true'
"withSection2": 'true'
"withSection3": 'false'
"withSection4": 'true'
}
所以方法签名就像drawScreen(jsonStr)
答案 0 :(得分:1)
对象之间的主要区别(如果你想使用与原型一起玩的简单对象)和JSON,你将无法使用JSON中的函数。
如果你不需要功能(从不),你肯定会选择JSON,因为它更具限制性,防止用户做你不想要的事情几乎总是一件好事。如果您打算这样做,这也可以帮助您将其与另一种语言一起使用。
但是,我创建了一个javascript / node.js框架(如果你想查看一个例子,我的配置文件中有一个链接),我广泛使用javascript对象进行配置,因为它实际上更加模块化(你可以将一些代码分解)变量,将一些文件合并在一起而不需要做很多工作,你在解释上赢得了一点性能,...)!哦,我忘记了重要的事情!你不能在JSON中使用评论。
这里有一些简单的例子(不要这样编码:):
<强>对象强>
// foo.js
var foo = {
foo: 1
};
// bar.js
var bar = {
bar: function() { return 2; }
};
// merge.js
var obj = merge(foo, bar); // Implement merge function once.
<强> JSON 强>
foo.json(无评论)
{
"foo": 1
}
bar.json(无评论)
{
"bar": 'no functions'
}
// merge.js
// You have to get the JSON files, then parse them (JSON.parse in javascript), then merge them.
正如我所说,您可以在我的个人资料中看到链接后更重要的使用对象。
<强>更新强>
如果要在JSON中设置默认值和/或哪个字段以及所需的字段类型,您当然应该有另一个JSON或对象来描述您的结构。在框架中,用户的输入是从合同文件处理的,例如:
var jsonConfiguration = '{"withSection1": false}';
var contract = {
withSection1: {
type: 'boolean',
default: true
},
withSection2: {
type: 'boolean',
default: true
},
withSection3: {
type: 'boolean',
default: false
},
withSection4: {
type: 'boolean',
default: true
}
}
// Check types, add default values if needed, ...
var configuration = processConfiguration(jsonConfiguration, contract);
drawScreen(configuration);
function processConfiguration(jsonConfiguration, contract) {
var configuration = JSON.parse(jsonConfiguration),
processedConfiguration = {}
;
for (var key in contract) {
if (undefined === configuration[key]) {
processedConfiguration[key] = contract[key].default;
} else {
processedConfiguration[key] = configuration[key];
}
}
return processedConfiguration;
}