使用toggleSourceEdit()
给我带来了一些问题。一个是这似乎使编辑器处于源代码编辑和所见即所得模式之间的某个地方,除非我使用 250 毫秒左右的超时。它还将焦点放在该编辑器中,我不想在编辑器中启动表单的焦点,特别是因为它位于首屏下方,并且浏览器在打开时会滚动到焦点所在的 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();
}
}
});