应用 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;
}
}