使用toggleSourceEdit()
对我造成了一些问题。一个是,这似乎把编辑器放在源编辑和所见即所得模式之间的某处,除非我使用250ms左右的超时。它还将焦点放在该编辑器中,我不想在编辑器中开始表单的焦点,特别是因为它处于低位,并且浏览器在打开时滚动到聚焦的HTML编辑器。
唯一对我有用的是延长Ext.form.HtmlEditor
,然后覆盖toggleSourceEdit
,删除焦点命令。然后在组件初始化时添加一个监听器来切换源代码编辑器。这适用于Ext 4.1及更高版本。对于旧版本,请将me.updateLayout()
替换为me.doComponentLayout()
。
var Namespace = {
SourceEditor: Ext.define('Namespace.SourceEditor', {
extend: 'Ext.form.HtmlEditor',
alias: 'widget.sourceeditor',
initComponent: function() {
this.callParent(arguments);
},
toggleSourceEdit: function (sourceEditMode) {
var me = this,
iframe = me.iframeEl,
textarea = me.textareaEl,
hiddenCls = Ext.baseCSSPrefix + 'hidden',
btn = me.getToolbar().getComponent('sourceedit');
if (!Ext.isBoolean(sourceEditMode)) {
sourceEditMode = !me.sourceEditMode;
}
me.sourceEditMode = sourceEditMode;
if (btn.pressed !== sourceEditMode) {
btn.toggle(sourceEditMode);
}
if (sourceEditMode) {
me.disableItems(true);
me.syncValue();
iframe.addCls(hiddenCls);
textarea.removeCls(hiddenCls);
textarea.dom.removeAttribute('tabindex');
//textarea.focus();
me.inputEl = textarea;
} else {
if (me.initialized) {
me.disableItems(me.readOnly);
}
me.pushValue();
iframe.removeCls(hiddenCls);
textarea.addCls(hiddenCls);
textarea.dom.setAttribute('tabindex', -1);
me.deferFocus();
me.inputEl = iframe;
}
me.fireEvent('editmodechange', me, sourceEditMode);
me.updateLayout();
}
})
}
然后使用它:
Ext.create('Namespace.SourceEditor', {
/*regular options*/
listeners: {
initialize: function(thisEditor) {
thisEditor.toggleSourceEdit();
}
}
});
感谢您的建议,但也没有工作。 – Wilerson 2010-10-22 19:26:23