最近在vue項目中需要使用富文本編輯器,于是將Ueditor集成進來,作為公共組件。
項目地址:https://github.com/suweiteng/vue2-management-platform
1.放入靜態資源并配置
首先把官網下載的Ueditor資源,放入靜態資源src/static中。

修改ueditor.config.js中的window.UEDITOR_HOME_URL配置,如下圖:

2.引入
在main.js中引入
import '../static/UE/ueditor.config.js'import '../static/UE/ueditor.all.min.js'import '../static/UE/lang/zh-cn/zh-cn.js'import '../static/UE/ueditor.parse.min.js'
3.開發公共組件
開發公共組件,可設置填充內容defaultMsg,配置信息config(寬度和高度等),并提供獲取內容的方法。
<template> <div>  <script id="editor" type="text/plain"></script> </div></template><script> export default {  name: 'UE',  data () {   return {    editor: null   }  },  props: {   defaultMsg: {    type: String   },   config: {    type: Object   }  },  mounted() {   const _this = this;   this.editor = UE.getEditor('editor', this.config); // 初始化UE   this.editor.addListener("ready", function () {    _this.editor.setContent(_this.defaultMsg); // 確保UE加載完成后,放入內容。   });  },  methods: {   getUEContent() { // 獲取內容方法    return this.editor.getContent()   }  },  destroyed() {   this.editor.destroy();  } }</script>4.使用
當我們需要使用富文本編輯器時,直接調用公共組件即可
<template> <div class="components-container">  <div class="info">UE編輯器示例<br>需要使用編輯器時,調用UE公共組件即可??稍O置填充內容defaultMsg,配置信息config(寬度和高度等),可調用組件中獲取內容的方法。</div>  <button @click="getUEContent()">獲取內容</button>  <div class="editor-container">   <UE :defaultMsg=defaultMsg :config=config ref="ue"></UE>  </div> </div></template><style> .info{  border-radius: 10px;  line-height: 20px;  padding: 10px;  margin: 10px;  background-color: #ffffff; }</style><script> import UE from '../../components/ue/ue.vue'; export default {  components: {UE},  data() {   return {    defaultMsg: '這里是UE測試',    config: {     initialFrameWidth: null,     initialFrameHeight: 350    }   }  },  methods: {   getUEContent() {    let content = this.$refs.ue.getUEContent();    this.$notify({     title: '獲取成功,可在控制臺查看!',     message: content,     type: 'success'    });    console.log(content)   }  } };</script>效果如下:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答