- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在将 ExtJS 用于 Web 应用程序。在该应用程序中,当需要简单的下拉列表时,我们使用标准的 Ext.form.ComboBox 控件,而当我们需要下拉列表时,我们使用 Ext.us.Andrie.Select 控件您可以在其中选择多个值和/或清除该值。创建这些中的任何一个总是需要一堆用于配置选项的样板代码,因此我想要一个可以减少样板代码的类,当我在做的时候,我希望这个类能够生成简单的下拉菜单或更高级的菜单一,取决于配置选项(multi: true
或 clearable: true
),但这比预期要困难得多。
这是我最接近的工作结果:
MyComboBox = (function() {
var singleDefaults = {
typeAhead: false,
triggerAction: 'all',
selectOnFocus: false,
allowBlank: true,
editable: false,
delay: 700
};
var multiDefaults = {
typeAhead: false,
triggerAction: 'all',
selectOnFocus: false,
allowBlank: true,
editable: false,
delay: 700
};
var constructor = function(config) {
if (config.multi || config.clearable) {
config = Ext.apply(this, config, multiDefaults);
Ext.apply(this, Ext.ux.Andrie.Select.prototype);
Ext.apply(this, Ext.ux.Andrie.Select(config));
Ext.ux.Andrie.Select.prototype.constructor.call(this, config);
} else {
config = Ext.apply(this, config, singleDefaults);
Ext.apply(this, Ext.form.ComboBox.prototype);
Ext.apply(this, Ext.form.ComboBox(config));
Ext.form.ComboBox.prototype.constructor.call(this, config);
}
};
return function(config) {
this.constructor = constructor;
this.constructor(config);
};
})();
嗯,它不会崩溃,但它也没有真正起作用。当设置为类似于 Ext.ux.Andrie.Select 的行为时,即使已加载,它也希望加载商店,除非您开始在字段中输入,否则不会展开下拉列表。
尝试过的另一种方法是这样的:
MyComboBox = Ext.extend(Ext.form.ComboBox, {
constructor: function(config){
if (config.multi || config.clearable) {
Ext.form.ComboBox.prototype.constructor.call(this, config);
} else {
Ext.ux.Andrie.Select.prototype.constructor.call(this, config);
}
}
});
这不起作用,因为 Andrie 下拉列表没有定义自己的构造函数
函数,因此它最终会调用 Ext.form.ComboBox
的构造函数,它继承自它,这会产生正常的下拉列表,而不是多选下拉列表。
我认为这是 ExtJS 特有的,但如果您有一个与框架无关的方法来执行此操作,我可能可以将其转换为 ExtJS。
最佳答案
在构建中型到大型 JavaScript 应用程序时,我发现将所有控件创建/实例化移动到单个类中很方便,因为每个方法都是该控件的工厂(即:组合框、文本区域、按钮、工具提示、复选框等)。由于只有工厂类知道如何创建控件,因此这具有将 View 逻辑与控件实例化本身解耦的额外好处(当然,只要控件构造函数和接口(interface)保持不变)。
WidgetFactory = {
comboBox: function(config) {
return config.multi || config.clearable
? this.comboBoxMultiple(config)
: this.comboBoxSingle(config)
},
comboBoxSingle: function(config) {
// ... boiler plate goes here ...
},
comboBoxMultiple: function(config) {
// ... boiler plate goes here ...
},
textArea : function(config) {},
textBox : function(config) {},
checkbox : function(config) {},
radioButton : function(config) {},
button : function(config) {},
slider : function(config) {},
colorPicker : function(config) {}
// etc
};
通过将控件创建与 View 解耦,您可以快速轻松地将一个控件的实现替换为另一个控件,而无需搜索整个应用程序来查找/替换该控件创建样板的所有实例。
<小时/>编辑:
我并不是想暗示这将取代创建/实例化控件的对象的使用,而是除此之外使用。使用 WidgetFactory
作为所有控件的单一网关比仅仅能够更改父类(super class)具有更大的灵 active 。您可以在不更改原始类的情况下交换整个类,从而允许您在必要时拥有多个不同的实现。
例如,如果您的单个组合框是由某个类定义的,namespace.ui.combobox.single
,那么您可以执行以下操作
comboBoxSingle: function(config) {
return new namespace.ui.combobox.single(config);
},
但是,如果您需要突然使用不同的类(也许是为了测试),您可以在工厂中更改它一次
comboBoxSingle: function(config) {
return new namespace.ui.combobox.single2(config);
},
并且可以轻松地来回切换,而无需更改实际的小部件类。
关于JavaScript/ExtJS : "Conditional Inheritance"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1959857/
现在我已经创建了一个额外的跨度来容纳一个条件。 568 || subKey == 0" ng-repeat="links in linksWrap.links">
一些 excel IF 语句可能会变得相当长,我正在寻找一种更简单的方法来编写它们。例如,如果我要写: If($B$4+13=7,$B$4+13,FALSE) 我认为它会更容易说: If($B$4+1
我有一个包含 FromDate 、 ToDate 、 VendorName 和 GoodsName 的表单,一旦一切为真,我需要显示结果 示例: FromDate="11/20/2019"、ToDat
我经常看到使用 !!condition 而不仅仅是常规条件的代码。即: if(!!value){ doSomething(); } 对比: if(value){ doSomething
这个问题有点模棱两可,这两个在汇编代码/性能方面是否等效: public void example{ do{ //some statements; if(condition)
在我看到的使用 Any 方法的 Linq 查询示例中,大约有一半是通过将其应用于 Where() 调用的结果来实现的,另一半则直接将其应用于集合。这两种样式是否总是等效的,或者在某些情况下它们可能会返
这个问题在这里已经有了答案: What does !!(x) mean in C (esp. the Linux kernel)? (3 个答案) 关闭 9 年前。 我见过人们使用带有两个 '!'
我对部署在生产环境中的应用程序进行了线程转储,该应用程序使用 logback。我不是分析线程转储的专家,但是,我必须这样做。正在学习,网上也看了一些文章。 下面是真正的线程转储: "logback-8
在 SQL 中(特别是 Postgres): 子句 where not foo='bar' in case foo is null 评估为某种 null,导致该行不是包含在结果中。 另一方面,子句 w
是不是类似于has and condition with join和where condition after join? 例如 对于以下两个查询,它会给我相同的结果吗 1) SELECT COUNT
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
如果您调用某个函数,并且该函数在发生错误时返回 NULL(例如,想想 malloc() 或 fopen()),两个更好: FILE *fp = fopen(argv[0], "r"); if (fp
我正在使用 Azure 数据工厂 V2,我需要在父检查验证中实现两级检查。例如:如果条件一为真,那么我需要检查条件 2。并且,如果条件 2 为真,则检查条件 3。 这是一种分层检查。当我在父 IF 条
使用 Linq to Entities 有以下区别吗? db.EntityName.Where(a => a.Id == id).FirstOrDefault(); db.EntityName.Fir
我有一种情况,我已经用两种不同的方式解决了,但想知道人们对这些选项的看法,以及他们是否有其他选择...... 系统正在处理数据的“间隔”。 所有数据都分配到一个“区间” 该间隔由事实表 中的“inte
我有包含字段 Amount, Condition1, Condition2 的表格。 例子: Amount Condition1 Condition2 ---------------------
我正在尝试在 Netbeans 中制作一个简单的 MySQL、Java JDBC Web 应用程序。我希望根据当前 session 中的状态变量显示不同的内容。我尝试了以下方法: 首先,我在 .jsp
我想为 postnuke cms 设计一个主题。 并希望在模板文件中使用 css 条件。 postnuke 使用类似 smarty 的标签 .... 所以当我使用 .... 它给出了一些关于标签的错误
我想问一下asyncio.Condition .我对这个概念并不熟悉,但我从学生时代就知道并了解锁、信号量和队列。 我找不到很好的解释或典型的用例,只是 this example .我看了看来源。核心
我想知道如何在不在语句中重做相同查询两次的情况下处理 SQL 比较。这是我要找的: SELECT columnName10, IF( SELECT columnName20 FROM Othe
我是一名优秀的程序员,十分优秀!