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:"<div id='"+activityHTMLId+"'></div>"
            }],
            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 会报错。所以进行了延迟渲染。

效果如图:


______________________________________________________________________________

另一种方式:

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);
                        }
                    }
                }
            }


转载于:https://my.oschina.net/Rayn/blog/309689

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值