使用wangEditor 粘贴图片时将图片上传到七牛云

如何使用wangEditor富文本编辑器:

文档地址:http://www.wangeditor.com/doc/

1.npm 安装

    npm 安装 npm i wangeditor --save

2.引入

    import E from "wangeditor";

3.使用-----在下面代码中展示

如何使用七牛云上传图片:

文档地址:https://developer.qiniu.com/kodo/sdk/1283/javascript

1.npm 安装

    npm install qiniu-js

2.引入

    constqiniu =require('qiniu-js') // or //  import*asqiniufrom'qiniu-js'

3.使用---下面案例中展示

使用wangEditor 粘贴图片时将图片上传到七牛云,返回图片路径

<div id="editor"> </div>      // 准备富文本渲染的盒子

<script>

import E from "wangeditor";  //引入wangEditor编辑器

import * as qiniu from "qiniu-js";    // 引入七牛云

export default{

data(){

   return{

        editor :" ",

        content :" "

   }

}

mounted() {

    let _this = this;

    this.editor = new E(document.getElementById("editor"));  

    this.editor.config.height = 370; //设置编辑器高度

    this.editor.config.customUploadImg = function (resultFiles, insertImgFn) {  //粘贴图片时的回调

       //resultFiles 粘贴的图片的基本信息

       //insertImgFn 图片上传到七牛云后对图片进行回显的回调函数

      resultFiles.forEach((element) => {    //循环对粘贴图片执行上传回显功能

        _this.getUploadToken(element, insertImgFn);  //上传图片到七牛云

      });

    };

    this.editor.config.onchange = function (newHtml) {  //实时获取富文本框内的内容

      _this.content = newHtml;

    };

    // 配置触发 onchange 的时间频率,默认为 200ms, 修改为 2000ms

    this.editor.config.onchangeTimeout = 2000; 

    this.editor.create();   //创建富文本编辑器

  },

methods:{

 //上传附件到七牛云---------------------------start

    getUploadToken(file, insertImgFn) {

      let _this = this;

      let suffix = file.name.substring(file.name.lastIndexOf(".") + 1);   //获取上传文件的后缀名

     const name =  (Math.random() * 10000000).toString(16).substr(0, 4) +  "-" + new Date().getTime() 

       + Math.random().toString().substr(2, 5) +  "." + suffix;  //构造唯一的文件名

      let key = "/file/" + file.size + "/" + name;  //生成key值

      this.http.request({   //请求后端接口,获取在七牛云的上传验证信息

          url: this.global.indexListPage.getRealUrl + "ossts/getUploadToken.action",

          data: {

            uploadType: "Img",

            bucket: "xy-no-control", //不走防盗链

          },

        }) .then((data) => {

          let token = data.configure.token;

          _this.domain = data.domain;

          const observable = qiniu.upload(file, key, token);   //  file: File 对象,上传的文件; key: 文件资源名; token: 上传验证信息,

          //前端通过接口请求后端获得

          const subscription = observable.subscribe(observer); // 上传开始

           const observer = { 

            next(res) {   //next: 接收上传进度信息的回调函数

              console.log("next", res);

            },

            error(err) {  //error: 上传错误后触发

              console.log("error", err);

            },

            complete(res) {  //complete: 接收上传完成后的后端返回信息,具体返回结构取决于后端sdk的配置

              _this.imgurl = _this.domain + res.key;  //生成图片的url

              insertImgFn(_this.imgurl);  //该方法是让粘贴的图片回显在富文本框内

            },

          };

        });

    }

    //上传附件--------------------------------end

}

}

</script>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容