tinymce vue 部分工具不显示_tinymce-vue使用问题及解决记录

一、本地图片上传:

1.转成base64,转换后的字符粘贴到notpadd++中看了下,有近20万个字符,所以直接没考虑

2.选择图片后调用后台方法传到服务器,保存后返回一个网络地址,传入success的回调方法,通过网络地址的方式显示。

前端配置代码如下:

images_upload_handler: (blobInfo, success, failure) => {

if (blobInfo.blob().size > 1048576) {

failure('文件体积过大')

}

// 发送到后台,传送到阿里云oss,返回上传后的网络地址

const uploadImgUrl =this.GLOBAL.WebSite + "/article/imgUpload";

var xhr, formData;

//原先用axios发文件一直不成功,参照官方文档。。第一次用XMLHttpRequest这鬼东西

xhr = new XMLHttpRequest();

xhr.withCredentials = false;

xhr.open('POST', uploadImgUrl);

formData = new FormData();

formData.append('file', blobInfo.blob());

xhr.onload = function() {

if (xhr.status != 200) {

failure('HTTP Error: ' + xhr.status);

return;

}

const result = JSON.parse(this.responseText);

if (!result || typeof result.value != 'string') {

failure('Invalid JSON: ' + xhr.responseText);

return;

}

// 后台返回json,对应的值的key是"value",所以这里为result.value

success(result.value);

}

xhr.send(formData);

}

阿里云买了个打折OSS服务器,上传OSS服务器的后台代码如下:

public static void uploadFile(MultipartFile multipartFile, String fileName) {

OSSClient ossClient = new OSSClient(AliyunOssConfig.getEndpoint(),

AliyunOssConfig.getAccessKeyId(), AliyunOssConfig.getAccessKeySecret());

try {

if (!ossClient.doesBucketExist(AliyunOssConfig.getDefaultBucketName())) {

ossClient.createBucket(AliyunOssConfig.getDefaultBucketName());

}

ossClient.putObject(AliyunOssConfig.getDefaultBucketName(), fileName,

multipartFile.getInputStream());

} catch (Exception e) {

logger.error(e,"uploadFile is error.");

} finally {

ossClient.shutdown();

}

}

上传成功后需要将阿里云OSS的文件获取路径返回给前端组件处理。具体格式为:bucketName.endpoint/fileName,

如:http://leslie1015.oss-cn-hangzhou.aliyuncs.com/1234.jpg,前端获取后传入success(url),组件将图片渲染为

package com.leslie.silk.config;

import org.springframework.beans.factory.annotation.Value;

import org.springframework.stereotype.Component;

/**

*阿里云OSS配置

/

@Component

public class AliyunOssConfig {

private static String endpoint;

private static String accessKeyId;

private static String accessKeySecret;

private static String defaultBucketName;

private static String endpointContent;

private AliyunOssConfig() {

}

public static String getEndpoint() {

return endpoint;

}

@Value("${aliyun.oss.endpoint}")

private void setEndpoint(String endpoint) {

AliyunOssConfig.endpoint = endpoint;

}

public static String getAccessKeyId() {

return accessKeyId;

}

@Value("${aliyun.oss.accessKeyId}")

private void setAccessKeyId(String accessKeyId) {

AliyunOssConfig.accessKeyId = accessKeyId;

}

public static String getAccessKeySecret() {

return accessKeySecret;

}

@Value("${aliyun.oss.accessKeySecret}")

private void setAccessKeySecret(String accessKeySecret) {

AliyunOssConfig.accessKeySecret = accessKeySecret;

}

public static String getDefaultBucketName() {

return defaultBucketName;

}

@Value("${aliyun.oss.defaultBucketName}")

private void setDefaultBucketName(String defaultBucketName) {

AliyunOssConfig.defaultBucketName = defaultBucketName;

}

public static String getEndpointContent() {

return endpointContent;

}

@Value("${aliyun.oss.endpointContent}")

public void setEndpointContent(String endpointContent) {

AliyunOssConfig.endpointContent = endpointContent;

}

}

二、桌面端富文本组件正常,移动端不显示

其实很简单。。。。愣是搞了半天

F12,切换到移动模式显示,发现是mobile/theme.js中的报错,原来是针对移动端有专门的js文件渲染,在/node_modules/tinymce/themes下存在两个目录,分别是silver和mobile,在封装组件的时候只引用了这个:

import 'tinymce/themes/silver'

加上如下引用:

import 'tinymce/themes/mobile'

手机端即可成功渲染

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/339919.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

清洁单元测试

使用JUnit和一些模拟库编写“单元测试”测试很容易。 即使测试甚至不是单元测试并提供可疑的价值,它们也可能产生使某些涉众满意的代码覆盖范围。 编写单元测试(在理论上是单元测试,但比基础代码更复杂)因此也很容易编写&#xff…

谷歌发布android+8.2,谷歌Pixel 2代三款新机齐曝光:骁龙835+Android 8.0

随着5月份谷歌I/O大会的临近,关于Android O(安卓8.0)和Pixel手机的消息逐渐多了起来。据外媒报道, Android Open Source Project的代码表中确认,三款Pixel新机搭载的都是MSM8998芯片,也就是骁龙835。目前,Pixel 2的代号…

怎么停止skywalking_Skywalking部署常见问题以及注意事项

Skywalking部署常见问题以及注意事项IntroSkyWalking 创建与2015年,提供分布式追踪功能。从5.x开始,项目进化为一个完成功能的Application Performance Management系统。他被用于追踪、监控和诊断分布式系统,特别是使用微服务架构&#xff0c…

akka的介绍_Akka笔记–演员介绍

akka的介绍过去做过多线程的任何人都不会否认管理多线程应用程序有多么艰辛和痛苦。 我说管理是因为它开始很简单,一旦您开始看到性能改进,它就会变得非常有趣。 但是,当您发现没有一种简单的方法可以从子任务中的错误或难以发现的僵尸错误中…

HTML语言name,HTML a 标签的 name 属性

延伸阅读:使用 name 属性还是 id 属性?在 HTML 4.0 之前的版本中,只有使用 标签的 name 属性才能创建片段标识符。随着 HTML 4.0 中 id 属性的出现,所有 HTML 或 XHTML 元素都可以是片段标识符。这是因为 id 标识符几乎可以用在所…

使用模拟进行测试

如果使用正确的方法,模拟对象将非常有用。 我在需要驱动软件开发使用的帖子中分享了一些使用Mock Objects的经验。 在这篇文章中,我分享了两件事 –使用模拟进行基于合同的测试。 –用于组织模拟代码的模式。 基于合同的测试 让我们以正在构建汇款服…

hazelcast_Hazelcast的MapLoader陷阱

hazelcastHazelcast提供的核心数据结构之一是IMap<K, V> &#xff0c;它扩展了java.util.concurrent.ConcurrentMap &#xff0c;它基本上是一个分布式地图&#xff0c;通常用作缓存。 您可以将此类地图配置为使用自定义MapLoader<K, V> -每次尝试从该地图&#xf…

html ul左侧浮动,UL里的LI元素左浮动层一行显示时使其居中的方法

在制作页面是&#xff0c;li浮动是很常用的&#xff0c;一般情况也不用其居中&#xff0c;但有时&#xff0c;其特殊原因需要居中&#xff0c;这是就有点犯难了&#xff0c;这里有了一个很好的解决方法&#xff0c;主要是用了相对定位的原理。在ul外报一层&#xff0c;使其相对…

aws s3 獲取所有文件_AWS SA associate 证书考试学习记录-EBS,S3,EFS比较

我们的目标&#xff0c;就是花最少的时间&#xff0c;学到最多的东西&#xff1a;-&#xff09;在AWS中&#xff0c;可以选择的存储服务很多&#xff0c;纷繁复杂&#xff0c;新手根本弄不清楚选择哪个。因为做为一个云架构师&#xff0c;你并不是让你的产品能用就够了&#xf…

ios调用restful接口_做iOS上最好的REST API测试App

对于Web开发者和移动应用开发者来说&#xff0c;少不了和REST API打交道。何为REST API&#xff0c;维基百科是这么解释的(https://zh.wikipedia.org/wiki/REST)REST(英文&#xff1a;Representational State Transfer)是Roy Thomas Fielding博士于2000年在他的博士论文中提出来…

Java 14:记录

Java 14是在几周前问世的&#xff0c;它引入了Record类型&#xff0c;它是一个不变的数据载体类&#xff0c;旨在容纳一组固定的字段。 请注意&#xff0c;这是预览语言功能 &#xff0c;这意味着必须使用--enable-preview标志在Java编译器和运行时中显式启用它。 我将直接介绍…

html设置顶部对齐,HTML / CSS文本从div顶部对齐

首先&#xff0c;你需要修复你的CSS选择器 .你可以通过这种方式t write all those id .#content #main #services只需选择1个元素和他的孩子 .例如&#xff0c;如果你测试它&#xff0c;它将适用于你&#xff1a;#services .langelis .txt {width: 440px;height: auto;float: l…

java与java ee_计划Java EE 7批处理作业

java与java eeJava EE 7添加了使用JSR 352以标准方式执行批处理作业的功能。 <job id"myJob" xmlns"http://xmlns.jcp.org/xml/ns/javaee" version"1.0"><step id"myStep"><chunk item-count"3"><rea…

html5 video 播放状态,10分钟了解HTML5的Video标签属性、方法和事件

标签的属性src &#xff1a;视频的属性poster&#xff1a;视频封面&#xff0c;没有播放时显示的图片preload&#xff1a;预加载autoplay&#xff1a;自动播放loop&#xff1a;循环播放controls&#xff1a;浏览器自带的控制条width&#xff1a;视频宽度height&#xff1a;视频…

hot编码 字符one_One Hot编码是什么?为什么要用它,什么时候用它?

作者&#xff1a;Rakshith Vasudev编译&#xff1a;ronghuaiyang导读当你在玩ML模型的时候&#xff0c;你会在任何地方遇到这个“One hot encoding”的术语。当你在玩ML模型的时候&#xff0c;你会在任何地方遇到这个“One hot encoding”术语。你可以看到一个one hot编码器的s…

CUBA 7.2 –有什么新功能?

CUBA平台的第七版向前迈出了一大步。 内部体系结构的改进和新的IDE为进一步改进奠定了良好的基础。 我们将继续添加新功能&#xff0c;以使开发人员的生活更轻松&#xff0c;并使他们的工作更加高效。 在7.2版中&#xff0c;我们引入了许多可能看起来像是主要更新的更改&#…

postgresql 分区视图_PostgreSQL架构集中式到分布式主流架构总结

文章目录一、PG未来主流架构为什么是分布式二、PostgreSQL集中式到分布式架构总结一、PG未来主流架构为什么是分布式如果说5年前DB的分布式还只是一种趋势&#xff0c;如今分布式数据库正逐渐从趋势变成主流。说到分布式&#xff0c;我想我们不能不提一下集中式和分库分表。01集…

html5 上传图片模板,HTML5实现图片文件异步上传

&#xff0c;过现前个能文使近记接的端问对字用近记接  利用HTML5的新特点做文件异步上传非常简单方便&#xff0c;本文主要展示JS部分&#xff0c;html结构。下面的代码并未使用第三发库&#xff0c;如果有参照&#xff0c;请注意一些未展现出来的代码片段。我这边的效果预览…

dot2谜团png_一个类加载的谜团解决了

dot2谜团png面对一个好老问题 我在应用程序服务器上遇到一些类加载问题。 这些库被定义为Maven依赖项&#xff0c;因此被打包到WAR和EAR文件中。 不幸的是&#xff0c;其中一些还安装在应用程序服务器中&#xff0c;但版本不同。 启动应用程序时&#xff0c;我们遇到了与这些类…

python log文件如何不写入syslog_Centos下python 对syslog重写进行日志记录

在Linux 环境下&#xff0c;python自带一个syslog的模块可以进行日志记录。python可以利用logging模块来重写syslog&#xff0c;这样就可以自定义写入文件的文件名。如果不做配置则直接写入到/var/log/message文件里。首先先写log.py,代码如下&#xff1a;importosimportsysimp…