乐趣区

关于element-ui:使用-ElementUI-image-处理富文本中的图片显示

应用 ElementUI image 解决富文本中的图片显示

成果


需要剖析

  • 因为富文本有 v-html 加载的,无奈应用 el-image,然而咱们又须要用到 el-image 组件
  • 须要预览视频富文本中的视频

图片解决办法

imageUrl: '',
imageUrls: []

> el-image 占用
<div class="elImage" style="display: none" v-if="imageUrl">
    <el-image ref="imageUrl" style="width: 100px; height: 100px;" :src="imageUrl" :preview-src-list="imageUrls"> </el-image>
</div>

bindImagesLayer() {
        let that = this;
        that.imageUrls = [];
        $('.content img').map(function(item) {that.imageUrls.push($(this).attr('src'));
        });
        $('body').on('click', '.content img', function() {let url = $(this).attr('src');
            if (!that.imageUrls.includes(url)) {that.imageUrls.push(url);
            }
            that.imageUrl = url;
            setTimeout(() => {$('.elImage img').click();}, 100);
        });
    }
    
async created() {await this.bindImagesLayer();
}

.content 为文章内容的 class,获取到其中所有的图片而后再填充到占用的 el-image 中,再手动触发 el-image 的点击事件

视频解决办法

咱们首先创立一个弹框组件,用于解决视频的预览

> 上面的这些变量本人 data 中注册一下

<el-dialog title="":visible.sync="videoVisible":append-to-body="true">
        <div class="videodDialog" v-if="videoVisible">
            <video :src="videoUrl" autoplay controls="controls"></video>
        </div>
</el-dialog>

咱们来解决视频的预览显示,先展现预览图再显示代码

video 的 html 构造如下

<div class="video">
            <video controls="controls" width="600" height="150" data-mce-fragment="1">
                <source src="https://trmk-cdn.teachingrecord.com/uploads/20201028/a7c8a18563a1b577537bef7fc25c3de2.mp4" type="video/mp4">
            </video>
            <div class="video-mask">
                <span class="video-icon"></span>
            </div>
        </div>
        

已知 html 构造,咱们来创立一下 css

>video.scss
video {
max-width: 100%;
margin: 0px auto;
cursor: pointer;

}

.video {
    position: relative;
    width: 320px;

    .video-mask {
        position: absolute;
        top: 0;
        width: 100%;
        height: 100%;
        cursor: pointer;

        .video-icon {
            content: '';
            position: absolute;
            left: 50%;
            top: 50%;
            display: block;
            transform: translate(-50%, -50%) scale(1.5);
            opacity: 1;
            transition: all 0.2s;
            padding: 14px;
            border-radius: 50%;
            width: 40px;
            height: 40px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: #fff;
            font-size: 20px;
            background-image: url();
            /* 你的图片 */
            background-size: 40px;
            z-index: 999;
            background-repeat: no-repeat;
            background-position: center center;
            cursor: pointer;
        }
    }

    .video-mask:hover {
        .video-icon {
            opacity: 1;
            transform: translate(-50%, -50%) scale(2.2);
        }
    }
}
.layui-layer-content {
    video {
        width: 100%;
        height: 95%;
    }
}

上述代码中,咱们的 icon 是 base64 转码的

再之须要应用动静 js 来管制,video 的展现

export default function videoContro(video, callback) {
    let videoContainer = video.parentNode;
    console.log(video);

    // 设置 poster 属性:(非本地视频资源会有跨域截图问题)video.addEventListener('loadeddata', function(e) {video.removeAttribute('controls');
    });

    let videoMask = document.createElement('div');
    videoMask.setAttribute('class', 'video-mask');

    let videoIcon = document.createElement('span');
    videoIcon.setAttribute('class', 'video-icon');
    videoMask.appendChild(videoIcon);

    videoContainer.appendChild(videoMask);

    /**
     * 设置播放状态
     */
    function vidplaySate(e) {let src = $(video)
            .children('source')
            .attr('src');

        callback(src);
    }
    videoMask.addEventListener('click', vidplaySate, false);
}

vue 调用管制形式

async created() {await this.bindImagesLayer();
    setTimeout(() => {this.initVideo();
    }, 1000);
}

method() {
    ...
    /**
    * 初始化播放器的一些配置
    */
    initVideo() {let videos = document.querySelectorAll('.docHtml video');
        let callback = this.videoCallback;
        videos.forEach(video => {videoContro(video, callback);
        });
    },

    videoCallback(src) {
        this.videoUrl = src;
        this.videoVisible = true;
    }
}

退出移动版