extjs3 html编辑器,Ext.js4.x 的面板中嵌入UEditor编辑器

代码如下:

var activityHTMLId;

Ext.define("ActivityHTMLInfo",{

extend:"Ext.panel.Panel",

initComponent:function(){

activityHTMLId = "activityHTML"+new Date().getTime() + "";

Ext.apply(this,{

items:[{

html:"

}],

listeners:{

render:function(){

var ue = UE.getEditor(activityHTMLId, {

height: 650

});

var activityContent = "";

var activityId = this.up("form").getForm().getFieldValues("activityId").activityId;

if(activityId){

setTimeout(function(){

Ext.getCmp("activityDetail").setActiveTab(2);

var record = Ext.getCmp("ActivityGridPanel").getSelectionModel().getLastSelected();

var content = record.data.activityContent;

if(content)

{

ue.setContent(content);     //ue.execCommand('insertHtml', content);

}

}, 600);

}

this.doLayout();

}

}

});

this.callParent();

}

});

关于UEditor方面的东西,自行参考UEditor的API说明。

之所以用到settimeout,是由于,Ext在渲染的过程中,有没有UEditor得不到这个渲染元素id 会报错。所以进行了延迟渲染。

效果如图:

c0030691b23e0855017ec4feb97b9f6d.png

______________________________________________________________________________

另一种方式:

items: {

xtype: 'component',

autoEl: {

tag: 'div'

},

id: win.editorId,

listeners: {

afterrender: function (c) {

var ue = UE.getEditor(win.editorId, {

});

ue.addListener('ready', function (editor) {

ue.setHeight(c.getHeight() - ue.container.firstChild.offsetHeight - 30);

});

},

beforedestroy: function (c) {

UE.delEditor(editorId);

},

resize: function (c) {

var ue = UE.getEditor(win.editorId);

if (ue.isReady == 1 || ue.isReady) {

ue.setHeight(c.getHeight() - ue.container.firstChild.offsetHeight - 30);

}

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值