tinymce5的图片上传实现

在vue created中初始化

      	tinymce.init({
			selector: '#tinymce-editor',
			language_url: "/tinymce/zh_CN.js",
			language: "zh_CN",
			height: 400,
			toolbar: "formatselect fontselect | bold italic underline strikethrough | alignleft aligncenter alignjustify | image | undo redo",
			menubar: false,
			statusbar: false,
			tinycomments_mode: 'embedded',
			plugins: 'advlist paste image imagetools',
			image_title: false,
    		automatic_uploads: false,
			paste_data_images: true,
			images_upload_handler: this.imgUpload
		});

images_upload_handler绑定对应的图片上传函数

		imgUpload (blobInfo, success, failure) {
			const formData = new FormData();
			formData.append('files', blobInfo.blob(), blobInfo.filename());
			axios.post('/api/file/post', formData).then((res) => {
				if(res.data.success) {
					this.$message({
						message: '上传成功',
						type: 'success',
						center: true
					});
					let url = res.data.urls[0].url
					this.imgString += url
					success(url)
				} else {
					this.$message({
						message: '上传失败',
						type: 'error',
						center: true
					});
					failure('')
				}
			}).catch((err) => {
				this.$message({
					message: '上传失败',
					type: 'error',
					center: true
				});
				failure('')
            })
		},

success(url)和failure('')对应上传状态回调

你可能感兴趣的:(vue,tinymce)