博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Ext.js4.x 的面板中嵌入UEditor编辑器
阅读量:6196 次
发布时间:2019-06-21

本文共 1543 字,大约阅读时间需要 5 分钟。

  hot3.png

代码如下:

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

你可能感兴趣的文章
8.Kubernetes Service(服务)
查看>>
图解DevExpress RichEditControl富文本的使用,附源码及官方API
查看>>
剖析 Laravel 计划任务--避免重复
查看>>
公司框架遇到的问题
查看>>
详解 Discuz 的 PHP经典加密解密函数 authcode
查看>>
Oracle如何删除表中重复记录
查看>>
nginx 是如何处理访问请求的
查看>>
wget参数用法详解
查看>>
【COCOS2D-X(1.X 2.X)】Json(cpp版)以及添加自定义字体库教程
查看>>
使用curl命令查看访问url的时间
查看>>
python添加环境变量
查看>>
DP-01背包 (题)
查看>>
WinForm中跨线程操作控件
查看>>
CODING 敏捷实践完全指南
查看>>
unittest测试框架和测试报告的输出实例(一)
查看>>
下MFC中对象、句柄、ID之间的区别.
查看>>
如何构建Win32汇编的编程环境(ONEPROBLEM个人推荐)
查看>>
Asp.Net MVC 分页、检索、排序整体实现
查看>>
python 输出当前行号
查看>>
12C -- 配置Application Continuity
查看>>