使用ckeditor时video和chart显示问题

一、ckeditor界面可以正常插入视频和图表

img

二、获取代码
(一)通过这个方式获取ckeditor内容

CKEDITOR.instances.editor1.document.getBody().$.innerHTML

(二)获取的内容

"++++++" name="++++++">一、播放视频</h1>

视频8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%221588%22%20height%3D%22886%22%3E%3C%2Fsvg%3E" data-cke-real-element-type="video">

" name="++++++">二、插入图表


1" contenteditable="false" data-cke-widget-wrapper="1" data-cke-filter="off" class="cke_widget_wrapper cke_widget_block cke_widget_chart cke_widget_wrapper_chartjs" data-cke-display-name="chart" data-cke-widget-id="4" role="region" aria-label="chart 小部件">
" data-chart="bar" data-chart-height="300" data-cke-widget-keep-attr="0" data-widget="chart" data-cke-widget-data="%7B%22chart%22%3A%22bar%22%2C%22height%22%3A%22200%22%2C%22classes%22%3A%7B%22chartjs%22%3A1%7D%2C%22values%22%3A%5B%7B%22value%22%3A399%2C%22label%22%3A%221%22%7D%2C%7B%22value%22%3A234%2C%22label%22%3A%223%22%7D%2C%7B%22value%22%3A453%2C%22label%22%3A%225%22%7D%2C%7B%22value%22%3A443%2C%22label%22%3A%226%22%7D%2C%7B%22value%22%3A124%2C%22label%22%3A%224%22%7D%5D%7D"> 200" width="300" style="width: 300px; height: 200px;">
">
" style="background:rgba(220,220,220,0.5);background-image:url(file:///D:/Program%20Files/hcyygl/maptest/ck/myeditor/ckeditor/plugins/widget/images/handle.png);display:none;"> " data-cke-widget-drag-handler="1" src="" width="15" title="点击并拖拽以移动" height="15" role="presentation"> >

三、新建html显示
(一)相关js和css引入

img


(二)html显示时,代码块和表格等都能显示,视频和图表不能显示。

img

img

img

请问要在html上显示视频和图表,如何设置呀 (ckeditor生成的视频和图表,总不可能在单独的html页面显示不了吧)

自己处理下视频和图标即可,增加下面的代码


<!--图标类库-->
<script src="../ckeditor/plugins/chart/lib/chart.min.js?t=MAUD"></script>
<script>
    ///视频替换
    $('[data-cke-realelement]').replaceWith(function () {
        return decodeURIComponent(this.getAttribute('data-cke-realelement')).replace(/cke:/gi, '')
    });


    function renderChart(canvas, data, legend) {
        var colors =
        {
            // Colors for Bar/Line chart: http://www.chartjs.org/docs/#bar-chart-data-structure
            fillColor: 'rgba(151,187,205,0.5)',
            strokeColor: 'rgba(151,187,205,0.8)',
            highlightFill: 'rgba(151,187,205,0.75)',
            highlightStroke: 'rgba(151,187,205,1)',
            // Colors for Doughnut/Pie/PolarArea charts: http://www.chartjs.org/docs/#doughnut-pie-chart-data-structure
            data: ['#B33131', '#B66F2D', '#B6B330', '#71B232', '#33B22D', '#31B272', '#2DB5B5', '#3172B6', '#3232B6', '#6E31B2', '#B434AF', '#B53071']
        };
        var config = { "Bar": { "animation": false }, "Doughnut": { "animateRotate": false }, "Line": { "animation": false }, "Pie": { "animateRotate": false }, "PolarArea": { "animateRotate": false } };
        var values = data.values,
            chartType = data.chart;
        var i, ctx = canvas.getContext('2d'),
            chart = new Chart(ctx);
        if (chartType != 'bar') {
            for (i = 0; i < values.length; i++) {
                values[i].color = colors.data[i];
                values[i].highlight = colors.data[i];
            }
        }
        if (chartType == 'bar' || chartType == 'line') {
            var data = {
                datasets: [
                    {
                        label: '',
                        fillColor: colors.fillColor,
                        strokeColor: colors.strokeColor,
                        highlightFill: colors.highlightFill,
                        highlightStroke: colors.highlightStroke,
                        data: []
                    }],
                labels: []
            };
            for (i = 0; i < values.length; i++) {
                if (values[i].value) {
                    data.labels.push(values[i].label);
                    data.datasets[0].data.push(values[i].value);
                }
            }
            legend.innerHTML = '';
        }

        if (chartType == 'bar') {
            chart.Bar(data, config.Bar);
        }
        else if (chartType == 'line') {
            chart.Line(data, config.Line);
        }
        else if (chartType == 'polar') {
            legend.innerHTML = chart.PolarArea(values, config.PolarArea).generateLegend();
        }
        else if (chartType == 'pie') {
            legend.innerHTML = chart.Pie(values, config.Pie).generateLegend();
        }
        else {
            legend.innerHTML = chart.Doughnut(values, config.Doughnut).generateLegend();
        }
    }
    $('[data-widget="chart"]').each(function () {
        var el = $(this);
        var data = JSON.parse(decodeURIComponent(el.attr('data-cke-widget-data')));
        var canvas = el.find('canvas')[0];
        var legend = el.find(".chartjs-legend")[0]
        renderChart(canvas, data, legend);
    })
/*  $(function(){
    $("code").each(function(){
      $(this).html("<ol><li>" + $(this).html().replace(//g,"
        </li><li>") + "
        </li></ol>");
    })
  })*/

</script>

提供一个参考实例【CKEditor5富文本编辑器 - 视频引入、预览及自定义toolbar】,链接:https://blog.csdn.net/huhui806/article/details/105312410