- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这个问题我想了很久,似乎想不出一个合理的解决办法。我想做的是在我看来为文本字段/它的值创建 getters/setters。我意识到首选的 Ext JS 方式是在 Controller 中使用引用并以这种方式获取它,但我觉得这不是很面向对象。我还必须包装这些 getter 和 setter,因为如果 getter 返回未定义,我想输出一条消息。我想做的是创建我自己的 getter/setter 或以某种方式覆盖默认的 getter/setter。以下是我想实现的一些方法。
我想我可以使用 config {}
,但这似乎只适用于我想定义的变量。然后我想以某种方式使用 id,但社区似乎对这是否是一种好的做法存在分歧。这导致了我当前的解决方案......包装。这是我的代码:
LoginWindow
Ext.define('MyApp.view.LoginWindow', {
extend: 'Ext.window.Window',
alias: 'widget.loginWindow',
autoShow: true,
closable: false,
border: 0,
plain: true,
allowBlank: false,
title: "Enter your username",
modal: true,
config: {
buttons: [{
text: "Ok"
}],
items: [{
xtype: 'textfield',
fieldLabel: 'Username',
id: 'loginUserInput',
name: 'loginUserInput',
msgTarget: 'under',
validator: function(value) {
if (Ext.isEmpty(value)) {
return "You need to enter a username.";
}
return true;
}
}]
},
constructor: function(config) {
this.callParent(config);
},
getButton: function() {
console.log('here');
}
});
MyController
Ext.define('MyApp.controller.Chat', {
extend: 'Ext.app.Controller',
requires: [
'Views.ChatModule.view.LoginWindow'
],
refs: [{
ref: 'loginWindow',
selector: 'loginWindow',
xtype: 'loginWindow',
autoCreate: true
}, {
ref: 'loginUserInput',
selector: '#loginUserInput'
}],
init: function() {
// The events controller oversees
this.control({
'loginWindow button[text="Ok"]': {
'click': this.onSubmitLoginWindow
}
});
},
getLoginUserInputValue: function() {
var loginUserInput = this.getLoginUserInput();
if (loginUserInput) {
var username = loginUserInput.getValue();
if (username) {
console.log(username);
} else {
console.warn("username is undefined");
}
}
console.warn("loginUserInput is undefined");
},
onSubmitLoginWindow: function(button, event, eOpts) {
this.getLoginUserInputValue();
}
});
这行得通,我意识到这是一件非常挑剔的事情,但在 Controller 中使用 getter 感觉不对。我觉得如果它在 Window 中,它会更面向对象。但是,如果我把它放在窗口中,我相信我唯一的选择是依靠 id 或在窗口的 initComponent 中手动创建文本字段——这将涉及保存那里的文本字段的引用,但这似乎有点低效...因为我也必须调用 doLayout。
重申一下,我希望在 Window 中有 getters/setters,我正在寻找一种引用它的快速方法,类似于 Controller 引用对象的方式。我相信主要的答案是使用 id 并在窗口中调用 Ext.ComponentQuery.query('#loginUserInput')
,但我想知道是否有更好的方法在那里...比如覆盖自动生成的 getter/setter 或为输入值添加一个简单的 getter/setter。
来自 Sencha forums 的交叉帖子.
编辑
我想我有点不清楚我想要什么。作为更笼统的陈述,我不想在 Controller 中塞满与我的 View 相关的所有内容,而是想将它们全部存储在 View 本身中,其中包括 getter/setter 之类的东西。这些 getter/setter 之一恰好是 loginUserInput getter。
使用模型是一个有趣的想法,但我觉得这对于单例值来说会是一大堆开销。我基本上是在寻找类似 Java 的 setters/getters 的东西在 LoginWindow View 中...希望像(或接近)Java 一样简单。
在 View 中包含(封装)它的想法使 Controller 更简洁,如果我删除 View ,我也会删除它的函数,所以我不必去寻找函数 Controller ...我只需要担心删除引用(应该是最小的)。
最佳答案
我认为您正在寻找的“面向对象”方式是使用表单的 Ext.data.Model
。如果您查看 Ext.form.Basic您有方法来操作模型(称为记录),还可以获取具有 View 值的对象。所以你需要:
loadRecord()
将表单绑定(bind)到模型。getValues()
检索表单字段的值。getRecord()
和 getValues()
同步您的记录。Ext.define('MyApp.model.Login',{
fields : [{
name: 'username',
type: 'string'
},{
name: 'password',
type: 'string'
}]
});
Ext.define('MyApp.controller.Login',{
...
refs : [{
selector: 'window form',
ref: 'formPanel'
}],
...
openForm : function() {
//load your form and then bind the new record
var formPanel = this.getFormPanel(), //Ext.form.Panel
form = formPanel.getForm(); //Ext.form.Basic
form.loadRecord(Ext.create('MyApp.model.Login'));
},
save : function() {
//get the values in the view
var form = this.getFormPanel().getForm(),
vals = form.getValues(),
record = form.getRecord();
console.log(vals); //see the object representation of your view here
record.set(vals); //update your model
//do whatever you need with your model
}
...
});
当您需要保存表单数据时,这是一个很好的例子。在登录中,我认为您可以直接使用 getValues()
而无需将其绑定(bind)到 Ext.data.Model
。
关于oop - 分机 JS 4 : Getters and setters in view,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18963412/
因此,我需要获取在为其赋值时调用的 setter 的名称。像这样: var b = {}; var a = { set hey(value) { b[] = value; } } 我希望 se
我是 Android 编程的新手(~ 2 个月)有必要为几十个不同的变量设置 getter 吗? 例如—— //Yes I realise that this isn't 'dozens' publi
import Control.Lens import Control.Lens.TH data Foo = Foo { _bar, _baz :: Int } makeLenses ''
我有点困惑:我可以覆盖 setter/getter 但仍然使用 super setter/getter 吗?如果是 - 怎么办? 用例: class A { void set value(num
我有一个接收消息的应用程序。消息中存在可编辑的字段。当字段更改时,应将其保存到数据库中。不幸的是,setter 仅在 setter 的范围内更改给定字段的值。知道为什么会发生这种情况吗?这是 gett
C# 中有没有一种方法可以让 setter 从“某物”继承,这样每次为特定基类及其继承者调用 setter 时,我都可以运行一些代码? 我想做的是在我的基类上有一个名为 IsValid 的 bool
可能是一个我无法解决的非常简单的问题 - 我从 C# 开始,需要使用 getter/setter 方法向数组添加值,例如: public partial class Form1 : Form {
这两个属性实现有什么区别? public override string A { get { return "s"; } set { } } public override strin
是否可以使用 abc.abstractproperty 创建一个具体的 getter 但将 setter 抽象为每个继承类的不同。我为每个子类处理不同的 val 设置。 例如。 @abstractpr
我在某处看到类似下面的内容,想知道它是什么意思。我知道他们是getter和setter,但是想知道为什么字符串Type是这样定义的。谢谢你帮助我。 public string Type { get;
Public class Example { private int number; public Example(int number){ this.number =
假设我有这样的代码: public response MyMethod(Request req) { String id = req.getFirst().geId(); } 我已经模拟了主对
允许这样做: public int Age { get; set; } 但是应用程序是否为变量创建/分配空间?我经常这样做 private int age = 0; public int Age {
我有一个条件,我构造字符串 (finalValue) 的方式是基于我在输入中获得的非空值的数量。所以我想知道是否可以用一个不同的参数为字符串 (finalValue) 重载 setter 方法并根据我
例如,在这段代码中 var o = { set a(value) {this.b = value}, get a() {return this.b} } 是否有可能获得对 o.a 的 sett
我一直在努力了解 getter 和 setter,但没有深入了解。我读过 JavaScript Getters and Setters和 Defining Getters and Setters只是没
我想在我的类中添加一个 getter 和 setter。然而,setter 应该接收一个 querySelector,但 getter 返回一个新类型 pageSections。 我的问题是 gett
使用有什么好处: private var _someProp:String; public function set someProp(value:String):void { _somePr
当从域类调用它时,我想在我的 setter 中执行一些操作,而不是从 hibernate 中调用它时。此外,我正在使用 session 工厂,因此我无法使用 @PostLoad 来触发标志! 有人对此
人员类别: public class Person { private String firstName; private String lastName; public Pe
我是一名优秀的程序员,十分优秀!