vue富文本框(插入文本、图片、视频)的使用及问题小结


Posted in Javascript onAugust 17, 2018

今天在vue里面插入富文本遇到了一些小坑在这里提供给大家用于参考,如有错误,望多加指正。

我这里使用的是Element-ui的上传图片组件

首先引入Element-ui(这个我就不作赘述了,详情参考element中文官网)

在引入富文本组件vue-quill-editor

使用在main.js引入相应的样式

import VueQuillEditor from 'vue-quill-editor'
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'
Vue.use(VueQuillEditor);

现在就可以在vue中使用富文本

<template>
<!--富文本编辑器-->
  <el-form-item label="内容" :label-width="formLabelWidth">
   <quill-editor v-model="value" ref="myQuillEditor" :options="editorOption" @change="onEditorChange($event)">
   </quill-editor>
  </el-form-item>
</template>
<script>
export default {
 data() {
  return {
        value:'',
  editorOption: {
   placeholder: '请输入院校简介',
   theme: 'snow',
   modules: {}
  }
      },
    methods: {
      onEditorChange() {
  console.log(this.value)
  }
    }
}
</script>

这里需要注意的是editorOption是必须要配置的

其样式由于没有在modules配置工具拦所以它的出事显示就较为简洁

如果需要上传图片或者视频就需要对模块里面对工具栏进行改造重构(使用handlers)

modules: {
   toolbar: {
    handlers: {
                container: toolbarOptions, // 工具栏
    'image': function(value) {
     if(value) {
     alert(1)
     } else {
     this.quill.format('image', false);
     }
    },
    'video': function(value) {
     if(value) {
     alert(2)
     } else {
     this.quill.format('image', false);
     }
    },
    }
   }
   }

配置好了过后会发现整个富文本编辑器的工具栏没有改变,还是只保留了几个基本的富文本功能。

vue富文本框(插入文本、图片、视频)的使用及问题小结

这个是因为handlers是用来定义自定义程序的,而添加自定义处理程序就会覆盖它本省的工具栏和主体行为所以我们还要再自行配置下自己需要的工具栏,所有功能的配置如下,大家也可以按需配置

const toolbarOptions = [
 ['bold', 'italic', 'underline', 'strike'], // toggled buttons
 ['blockquote', 'code-block'],
 [{
  'header': 1
 }, {
  'header': 2
 }], // custom button values
 [{
  'list': 'ordered'
 }, {
  'list': 'bullet'
 }],
 [{
  'script': 'sub'
 }, {
  'script': 'super'
 }], // superscript/subscript
 [{
  'indent': '-1'
 }, {
  'indent': '+1'
 }], // outdent/indent
 [{
  'direction': 'rtl'
 }], // text direction
 [{
  'size': ['small', false, 'large', 'huge']
 }], // custom dropdown
 [{
  'header': [1, 2, 3, 4, 5, 6, false]
 }],
 [{
  'color': []
 }, {
  'background': []
 }], // dropdown with defaults from theme
 [{
  'font': []
 }],
 [{
  'align': []
 }],
 ['link', 'image', 'video'],
 ['clean'] // remove formatting button
 ]

此时的文本工具就会丰富了

vue富文本框(插入文本、图片、视频)的使用及问题小结

这样它的工具栏就会有上传图片和视频的接口,然后你就可以在工具拦的配置里的image和video里配置上传图片或视频,可以根据它的点击来给他相应的处理回应,也可以为其重新定向事件,这里我这里给大家介绍重新定向事件

首先定义一个上传组件,我这里用的是自己写好的上传 组件

<div class='avatar-uploader'>
 <myUp v-on:getImgUrl='AddInputUrl'></myUp>
</div>

设置好相应属性值和事件

<script>
import myUp from '@/page/test' //上传组件
  export default {
    data() {
      return { 
        value:'',          
        editorOption: {
   placeholder: '请输入院校简介',
   theme: 'snow', // or 'bubble'
   modules: {
   toolbar: {
    container: toolbarOptions, // 工具栏
    handlers: {
    'image': function(value){
     if(value) {
//     console.log(this.serverUrl)
     document.querySelector('.avatar-uploader').click()
//                alert(1)
     } else {
     this.quill.format('image', false);
     }
    },
    'video': function(value) {
     if(value) {
     alert(2)
     } else {
     this.quill.format('image', false);
     }
    },
    }
   }
   }
  }, 
      }
    },
    methods: {
      onEditorChange() {
  console.log(this.value)
  var conten = this.value
  this.$emit('getText',conten)
  }
    }
  }
</script>

这里需要注意的是如果想直接实现上传的话就需要在工具栏设置点击图片上传的时候用指针函数将this锁定再做其他操作

由于我是自己写的上传所以要插入到富文本内部所以添加内容的时候需要加入img标签,因为富文本内部是支持图片的解析的

AddInputUrl(data) {
  var a = data
  var tp = a.length
  var imghz = a.slice(tp - 4, tp)
  var src = 'src="' + a + '"'
  var bq = "<img " + src + " alt='' />"
  this.value += bq
}

做到这里一个支持上传图片的富文本就做好了,再来说下视频,由于引入的富文本绝大多数都是没有内置的播放器所以video标签在富文本里面会失效,在这里我就选择直接用iframe标签

var bq='<iframe frameborder="0" width="100%" height="40%" '+ src+' allowfullscreen></iframe>'
this.value += bq

总结

以上所述是小编给大家介绍的vue富文本框(插入文本、图片、视频)的使用及问题小结,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Safari5中alert的无限循环BUG
Apr 07 Javascript
一个JS函数搞定网页标题(title)闪动效果
May 13 Javascript
Javascript学习笔记之函数篇(六) : 作用域与命名空间
Nov 23 Javascript
javascript获取网页宽高方法汇总
Jul 19 Javascript
sso跨域写cookie的一段js脚本(推荐)
May 25 Javascript
Javascript获取图片原始宽度和高度的方法详解
Sep 20 Javascript
jQuery选择器之属性过滤选择器详解
Sep 28 jQuery
基于vue-cli 打包时抽离项目相关配置文件详解
Mar 07 Javascript
vue vue-Router默认hash模式修改为history需要做的修改详解
Sep 13 Javascript
详解Vue2.0组件的继承与扩展
Nov 23 Javascript
Vue 中的受控与非受控组件的实现
Dec 17 Javascript
jquery实现动态创建form并提交的方法示例
May 27 jQuery
浅析vue给不同环境配置不同打包命令
Aug 17 #Javascript
React中使用async validator进行表单验证的实例代码
Aug 17 #Javascript
JavaScript实现构造json数组的方法分析
Aug 17 #Javascript
layer弹出层父子页面事件相互调用方法
Aug 17 #Javascript
layer.open 按钮的点击事件关闭方法
Aug 17 #Javascript
layer弹出层全屏及关闭方法
Aug 17 #Javascript
vue+iview+less 实现换肤功能
Aug 17 #Javascript
You might like
Optimizer与Debugger兼容性问题的解决方法
2008/12/01 PHP
windows7下安装php的php-ssh2扩展教程
2014/07/04 PHP
PHP实现Soap通讯的方法
2014/11/03 PHP
PHP实现统计所有字符在字符串中出现次数的方法
2017/10/17 PHP
PHP实现根据数组某个键值大小进行排序的方法
2018/03/13 PHP
JS 动态加载脚本的4种方法
2009/05/05 Javascript
js中将URL中的参数提取出来作为对象的实现代码
2011/08/16 Javascript
使用js实现的简单拖拽效果
2015/03/18 Javascript
jQuery AjaxUpload 上传图片代码
2016/02/02 Javascript
简单实现js点击展开二级菜单功能
2017/05/16 Javascript
微信小程序基于本地缓存实现点赞功能的方法
2017/12/18 Javascript
解决axios发送post请求返回400状态码的问题
2018/08/11 Javascript
js for终止循环 跳出多层循环
2018/10/04 Javascript
JS中数据结构与算法---排序算法(Sort Algorithm)实例详解
2019/06/17 Javascript
vue ssr服务端渲染(小白解惑)
2019/11/10 Javascript
node.js中Buffer缓冲器的原理与使用方法分析
2019/11/23 Javascript
ant-design-vue 快速避坑指南(推荐)
2020/01/21 Javascript
vue 实现setInterval 创建和销毁实例
2020/07/21 Javascript
python提取内容关键词的方法
2015/03/16 Python
在树莓派2或树莓派B+上安装Python和OpenCV的教程
2015/03/30 Python
python基于隐马尔可夫模型实现中文拼音输入
2016/04/01 Python
pytorch 转换矩阵的维数位置方法
2018/12/08 Python
python打印n位数“水仙花数”(实例代码)
2019/12/25 Python
python实现替换word中的关键文字(使用通配符)
2020/02/13 Python
PyTorch 中的傅里叶卷积实现示例
2020/12/11 Python
CSS3实现背景透明文字不透明的示例代码
2018/06/25 HTML / CSS
Html5上传图片 移动端、PC端通用代码
2016/06/08 HTML / CSS
金融专业推荐信
2013/11/14 职场文书
贷款委托书范本
2014/04/08 职场文书
中秋手机店促销方案
2014/06/16 职场文书
中小学生学籍证明
2014/10/25 职场文书
优秀班组申报材料
2014/12/25 职场文书
会计工作岗位职责
2015/02/03 职场文书
安全保证书格式
2015/02/28 职场文书
MySQL中B树索引和B+树索引的区别详解
2022/03/03 MySQL
vue使用echarts实现折线图
2022/03/21 Vue.js