jeecgBoot富文本改造,支持上传本地视频-vue2版本

步骤一:找到JEditor.vue文件

具体路径:src/components/jeecg/JEditor.vue

步骤二:把代码复制进去(其实简单看下哪里不一样复制不同点就可以        )

 主要逻辑是 这个

file_picker_callback: function (callback, value, meta) {
<template>
  <div class="tinymce-editor">
    <editor
      v-if="!reloading"
      v-model="myValue"
      :init="init"
      :disabled="disabled"
      @onClick="onClick">
    </editor>
  </div>
</template>

<script>
import tinymce from 'tinymce/tinymce'
import Editor from '@tinymce/tinymce-vue'
import 'tinymce/themes/silver/theme'
import 'tinymce/plugins/image'
import 'tinymce/plugins/link'
import 'tinymce/plugins/media'
import 'tinymce/plugins/table'
import 'tinymce/plugins/lists'
import 'tinymce/plugins/contextmenu'
import 'tinymce/plugins/wordcount'
import 'tinymce/plugins/colorpicker'
import 'tinymce/plugins/textcolor'
import 'tinymce/plugins/fullscreen'
import 'tinymce/icons/default'
import { uploadAction,getFileAccessHttpUrl } from '@/api/manage'
import { getVmParentByName } from '@/utils/util'
export default {
  components: {
    Editor
  },
  props: {
    value: {
      type: String,
      required:false
    },
    triggerChange:{
      type: Boolean,
      default: false,
      required:false
    },
    disabled: {
      type: Boolean,
      default: false
    },
    plugins: {
      type: [String, Array],
      default:
        "preview searchreplace autolink directionality visualchars image link media table hr pagebreak anchor insertdatetime advlist lists wordcount autosave indent2em",
    },
    toolbar: {
      type: [String, Array],
      default: 'undo redo |  formatselect | bold italic | alignleft aligncenter alignright alignjustify | bullist numlist outdent indent | lists link unlink image media table | removeformat | fullscreen',
      branding:false
    }
  },
  data() {
    return {
      //初始化配置
      init: {
        language_url: '/tinymce/langs/zh_CN.js',
        language: 'zh_CN',
        skin_url: '/tinymce/skins/lightgray',
        height: 300,
        plugins: this.plugins,
        toolbar: this.toolbar,
        branding: false,
        menubar: false,
        toolbar_drawer: false,
        //update-begin-author:taoyan date:2022-5-6 for: issues/I4BCC3 富文本编辑器在服务器图片上传是相对路径
        convert_urls: false,
        //update-end-author:taoyan date:2022-5-6 for: issues/I4BCC3 富文本编辑器在服务器图片上传是相对路径
        images_upload_handler: (blobInfo, success) => {
          let formData = new FormData()

          formData.append('file', blobInfo.blob(), blobInfo.filename());
          formData.append('biz', "jeditor");
          formData.append("jeditor","1");
          uploadAction(window._CONFIG['domianURL']+"/sys/common/upload", formData).then((res) => {
            if (res.success) {
              if(res.message == 'local'){
                const img = 'data:image/jpeg;base64,' + blobInfo.base64()
                success(img)
              }else{
                let img = getFileAccessHttpUrl(res.message)
                success(img)
              }
            }
          })
        },
        file_picker_callback: function (callback, value, meta) {
          if (meta.filetype === "media") {
            // 模拟上传本地视频
            let input = document.createElement("input");
            input.setAttribute("type", "file");
            input.setAttribute("accept", ".mp4");
            input.onchange = function () {
              let file = this.files[0];
              let fd = new FormData();
              fd.append("file", file);
              //调用方法,上传文件,请求路径为配置路径+/sys/common/upload,根据实际上传接口更改
              uploadAction(window._CONFIG['domianURL']+"/sys/common/upload", fd).then((res) => {
                //获取改文件上传后的全路径,通过jeecgboot的获取文件方法:具体路径为配置路径+获取文件的方法+文件名
                let r1 = getFileAccessHttpUrl(res.message);
                callback(r1);
              });
            };
            input.click();
          }
        },
      },
      myValue: this.value,
      reloading: false,
    }
  },
  mounted() {
    this.initATabsChangeAutoReload()
  },
  methods: {

    reload() {
      this.reloading = true
      this.$nextTick(() => this.reloading = false)
    },

    onClick(e) {
      this.$emit('onClick', e, tinymce)
    },
    //可以添加一些自己的自定义事件,如清空内容
    clear() {
      this.myValue = ''
    },

    /**
     * 自动判断父级是否是 <a-tabs/> 组件,然后添加事件监听,自动触发reload()
     *
     * 由于 tabs 组件切换会导致 tinymce 无法输入,
     * 只有重新加载才能使用(无论是vue版的还是jQuery版tinymce都有这个通病)
     */
    initATabsChangeAutoReload() {
      // 获取父级
      let tabs = getVmParentByName(this, 'ATabs')
      let tabPane = getVmParentByName(this, 'ATabPane')
      if (tabs && tabPane) {
        // 用户自定义的 key
        let currentKey = tabPane.$vnode.key
        // 添加事件监听
        tabs.$on('change', (key) => {
          // 切换到自己时执行reload
          if (currentKey === key) {
            this.reload()
          }
        })
        //update--begin--autor:liusq-----date:20210316------for:富文本编辑器tab父组件可能导致的赋值问题------
        this.reload()
        //update--end--autor:liusq-----date:20210316------for:富文本编辑器tab父组件可能导致的赋值问题------
      }else{
        //update--begin--autor:wangshuai-----date:20200724------for:富文本编辑器切换tab无法修改------
        let tabLayout = getVmParentByName(this, 'TabLayout')
        //update--begin--autor:liusq-----date:20210713------for:处理特殊情况excuteCallback不能使用------
        try {
          tabLayout.excuteCallback(() => {
            this.reload()
          })
        } catch (error) {
          if (tabLayout) {
            this.reload()
          }
        }
        //update--end--autor:liusq-----date:20210713------for:处理特殊情况excuteCallback不能使用------
        //update--begin--autor:wangshuai-----date:20200724------for:文本编辑器切换tab无法修改------
      }
    },

  },
  watch: {
    value(newValue) {
      this.myValue = (newValue == null ? '' : newValue)
    },
    myValue(newValue) {
      if(this.triggerChange){
        this.$emit('change', newValue)
      }else{
        this.$emit('input', newValue)
      }
    },
    //update--begin--autor:liusq-----date:20230420------for:[issues/19]缓存路由后,页面中富文本组件会出现无法编辑的问题------
    '$route': function(newRoute) {
      if(this.$route.meta.keepAlive && this.$route.meta.componentName){
        this.reload()
      }
    }
    //update--end--autor:liusq-----date:20230420------for:[issues/19]缓存路由后,页面中富文本组件会出现无法编辑的问题------
  }
}

</script>
<style scoped>
</style>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值