2

有没有办法对具有相同设置的自定义控件的 javascript 进行分组?

示例:

我将 3 个自定义控件放在一个页面上。每个人都写一个类似的javascript

ucx.initialize( controlID, settings );

所以我得到...

ucx.initialize("txtValue1", { sync: true, mask: '0 km' });
ucx.initialize("txtValue2", { sync: true, mask: '0 km' });
ucx.initialize("txtValue3", { sync: true, mask: '0 mm'});

如我们所见,“txtValue1”和“txtValue2”具有相同的设置。

所以我想将它们分组:

ucx.initialize(["txtValue1", "txtValue2"], { sync: true, mask: '0 km'});
ucx.initialize("txtValue3", { sync: true, mask: '0 mm'});

有可能的?

4

2 回答 2

0

这完全取决于你的initialize功能做什么。

至少,您可以使用默认的通用设置对象:

var initialize = function (controlID, settings) { 
    ...
    settings = settings || { sync: true, mask: '0 km'};
    ... 
};

然后,如果您在不传递设置对象的情况下调用该函数,则默认为常见的:

ucx.initialize("txtValue1");
ucx.initialize("txtValue2");
ucx.initialize("txtValue3", { sync: true, mask: '0 mm'});
于 2012-08-14T13:18:07.060 回答
0

您可以创建自己的类似工作的方法:

ucx.initializeMultiple = function() {
    var settings = arguments[arguments.length - 1];
    for (var i = 0; i < arguments.length - 1; i++) {
        ucx.initialize(arguments[i], settings);
    }
}

然后,您可以调用:

ucx.initializeMultiple("txtValue1", "txtValue2", { sync: true, mask: '0 km'});

您可以根据需要在参数中放置任意数量的字段名称。最后一个参数是设置对象。它之前的所有参数都被解释为每个都应该获取该设置的字段名称。


请记住,设置不必是内联的。如果不创建这个新方法,您也可以这样做以避免重复设置:

var settings1 = { sync: true, mask: '0 km'};
ucx.initialize("txtValue1", settings1);
ucx.initialize("txtValue2", settings1);
于 2012-08-14T13:27:18.707 回答