IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue引入tinymce -> 正文阅读

[JavaScript知识库]vue引入tinymce

官方文档

Using the TinyMCE .zip package with the Vue.js framework | TinyMCE Documentation

其实官方也就两步

1.安装Vue CLI 工具

npm install -g @vue/cli

2.引入

npm install --save "@tinymce/tinymce-vue@^3"

这里我是vue2所以是这个文档中是这样的

3.页面引入新增一个vue页面 test.vue

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png">
    <editor
      api-key="no-api-key"
      :init="{
        plugins: 'lists link image table code help wordcount'
      }"
    />
  </div>
</template>

<script>
import Editor from '@tinymce/tinymce-vue'

export default {
  name: 'app',
  components: {
    'editor': Editor
  }
}
</script>

4.实现效果,剩下估计要配置什么上传图片等功能了

5.解决烦人的弹窗问题

Self Hosted WYSIWYG HTML Editor | Trusted Rich Text Editor | TinyMCE

下载最新的版本把其中的

拷到无需打包的目录下

并在index.html中引入,凡人的弹窗就莫得了

6.汉化中文包下载地址,进去搜索chinese即可

Language Packages | Trusted Rich Text Editor | TinyMCE

下载完将js文件解压到之前的文件夹的lang下

设置init参数

7.添加图片上传功能

官方文档地址

Image and file options | TinyMCE Documentation


?

?修改options属性,在官方文档上自己抄下吧 太长了 忍一下

?

当然这里的图片不晓得传哪里去了需要配置在上边的options中添加一个url

images_upload_url: 'sys/upload/img'

上传的对象为file,后端如下

因为我这边上传端口其他也有用到,所以文件名为upfile怎么改呢,官网也有例子

?

一般是直接放在文件的这里即可,但是我的url每次都要this.$http.addUrl()来拼接后端地址,但是this并不能在const对象中被使用,所以后面改改成放在method,并且修改读取返回数据的时候也添加地址

methods: {
      example_image_upload_handler (blobInfo, progress) {
        return new Promise((resolve, reject) => {
          const xhr = new XMLHttpRequest()
          xhr.withCredentials = false
          xhr.open('POST', this.$http.adornUrl('/sys/upload/img'))

          xhr.upload.onprogress = e => {
            progress(e.loaded / e.total * 100)
          }

          xhr.onload = () => {
            if (xhr.status === 403) {
              reject({ message: 'HTTP Error: ' + xhr.status, remove: true })
              return
            }

            if (xhr.status < 200 || xhr.status >= 300) {
              reject('HTTP Error: ' + xhr.status)
              return
            }

            const json = JSON.parse(xhr.responseText)

            if (!json || typeof json.msg !== 'string') {
              reject('Invalid JSON: ' + xhr.responseText)
              return
            }

            resolve(this.$http.adornUrl(json.msg))
          }

          xhr.onerror = () => {
            reject('Image upload failed due to a XHR Transport error. Code: ' + xhr.status)
          }

          const formData = new FormData()
          formData.append('upfile', blobInfo.blob(), blobInfo.filename())

          xhr.send(formData)
        })
      },
    },

还有需要在options中添加

images_upload_handler: this.example_image_upload_handler,

样例如下视频

QQ录屏20220511143949

最后添加保存和清空按钮

?

?

 <div class="btn-div">
      <el-button size="mini" @click="submit">保存</el-button>
      <el-button type="danger" size="mini" @click="clear">清空</el-button>
    </div>
 submit () {
        if (!this.$listeners['submit']) {
          this.$message.error('没有传入组件方法submit')
          return
        }
        this.$emit('submit', this.myValue)
      },
      clear () {
        this.myValue = ''
      },

?父组件调用

最后是整个测试文件

tinymce-editor测试vue-Javascript文档类资源-CSDN下载

?

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-12 16:23:29  更:2022-05-12 16:25:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:51:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码