富文本编辑器CKEditor4简单使用-04(跟源码设置image2插件图片的默认宽高等相关配置)

本文主要是介绍富文本编辑器CKEditor4简单使用-04(跟源码设置image2插件图片的默认宽高等相关配置),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

富文本编辑器CKEditor4简单使用-04(跟源码设置image2插件图片的默认宽高等相关配置)

  • 1. 前言
    • 1.1 CKEditor4快速上手
  • 2. CKEditor4的一般配置
    • 2.1 工具栏相关
    • 2.2 插件相关
    • 2.3 设置界面宽高等
  • 3. CKEditor4的图片相关配置
    • 3.1 关于增强的图像插件的必要配置
    • 3.2 隐藏image2插件的上传界面的URL
      • 3.2.1 默认界面
      • 3.2.2 修改源码,隐藏
    • 3.3 禁止图片上传完毕后自动填充图片长和宽
    • 3.4 上传图片之后设置宽、高默默认值
      • 3.4.1 说明
      • 3.4.2 跟源码,找控制款高的代码
      • 3.4.3 方法1:修改源码1处(在 image2.js 里更改)
        • 3.4.3.1 添加宽高默认配置(代码1处 简单设置——初版)
        • 3.4.3.2 添加宽高默认配置(代码1处 简单设置——优化1)
        • 3.4.3.3 添加宽高默认配置(代码1处 简单设置——优化2)
      • 3.4.4 方法2:修改源码2处(在 plugin.js 里更改)
        • 3.4.4.1 说明
        • 3.4.4.2 在 plugin.js 中实现宽高默认配置(问题)
  • 4. 更多配置

1. 前言

1.1 CKEditor4快速上手

  • 快速入门,如下:
    富文本编辑器CKEditor4简单使用-01(入门).
  • 关于CKEditor4的插件安装及使用,如下:
    富文本编辑器CKEditor4简单使用-02(常用插件安装及使用).
  • 关于CKEditor4的图片上传功能
    富文本编辑器CKEditor4简单使用-03(图片上传).

2. CKEditor4的一般配置

2.1 工具栏相关

  • 工具栏配置组(一般配置),配置属性,例子如下:
    config.toolbarGroups = [{ name: 'document', groups: [ 'mode', 'document', 'doctools' ] },'/',{ name: 'paragraph', groups: [ 'list', 'indent', 'blocks', 'align', 'bidi', 'paragraph' ] },'/',{ name: 'styles', groups: [ 'styles' ] },{ name: 'colors', groups: [ 'colors' ] },
    ];
    
  • 工具栏配置(高级配置),配置属性,例子如下:
    config.toolbar = [{ name: 'document', items: [ 'Source', '-', 'Save', 'ExportPdf', 'Preview', 'Print', '-', 'Templates' ] },{ name: 'insert', items: [ 'Image', 'Table', 'HorizontalRule', 'Smiley', 'SpecialChar' ] },'/',{ name: 'styles', items: [ 'Styles', 'Format', 'Font', 'FontSize' ] },'/',{name: 'paragraph', items: ['NumberedList', 'BulletedList', 'Language']}
    ];
    
  • 工具栏中移除不需要的按钮工具,例如:
    config.removeButtons = 'Strike,Subscript,Superscript,Outdent,Language';
    
  • 关于工具栏的更多,入门文章里有些,可参考:
    富文本编辑器CKEditor4简单使用-01(入门).

2.2 插件相关

2.3 设置界面宽高等

  • 更多请去官网,这些都是源码自带的可配置的!

3. CKEditor4的图片相关配置

3.1 关于增强的图像插件的必要配置

  • 开启插件,如下:
    config.extraPlugins = 'image2,uploadimage';
    
  • 接口配置,如下:
    // 1. 注释掉的话,【上传】按钮不展示
    config.filebrowserImageUploadUrl = 'http://localhost:8993/cke4/file/upload/uploadFileTest2';// 2. 这个配置是用于拖拉拽,贴图
    config.uploadUrl = 'http://localhost:8993/cke4/file/upload/uploadFileTest2';// 3. 这个注释掉可能使增强上传图片界面失效,回到默认界面,【上传】按钮丢失(只是可能失效)
    // config.filebrowserImageBrowseUrl = 'http://localhost:8993/cke4/file/upload/uploadFileTest2'; // 4. filebrowserImageBrowseUrl 与 filebrowserBrowseUrl都注释掉的话,【浏览服务器】按钮不展示
    // config.filebrowserBrowseUrl = 'http://localhost:8993/cke4/file/upload/uploadFileTest2';// 5. 这个配置是控制什么的?
    // config.filebrowserUploadUrl = 'http://localhost:8993/cke4/file/upload/uploadFileTest2';
    

3.2 隐藏image2插件的上传界面的URL

3.2.1 默认界面

  • 如下:
    在这里插入图片描述

3.2.2 修改源码,隐藏

  • 这个好像没有对应的配置项,如果想要隐藏,需要修改源码。
  • 修改处代码如下:
    • 修改前代码:
      在这里插入图片描述
    • 修改后代码:
      // 自定义配置项 image2_server_url_hideFlage ,如果配置了false就不隐藏,否则隐藏(即:默认是隐藏的)
      hidden: editor.config.image2_server_url_hideFlage === false ? false : true,
      
      在这里插入图片描述
  • 然后就可以使用配置控制展示和隐藏,看效果:
    • 如果不加配置,默认隐藏:
      在这里插入图片描述
    • 如果配置false,就展示:
      config.image2_server_url_hideFlage = false;
      
      在这里插入图片描述

3.3 禁止图片上传完毕后自动填充图片长和宽

  • 这个是系统自带的参数,可以配置,先看默认不配置的效果:
    在这里插入图片描述
  • 如果配置 false 之后,效果如下(不过,个人觉得这个没有必要设置,显示着还挺好,还方便对比调整图片大小):
    // 设置为false,禁止图片上传完毕后自动填充图片长和宽
    config.image2_prefillDimensions = false;
    
    在这里插入图片描述

3.4 上传图片之后设置宽、高默默认值

3.4.1 说明

  • 为啥有想设置默认值的需求,主要是有的图片太大,上传之后铺满了编辑区域,虽然可拖拽改变尺寸,但是目前还得找到图片的最右下角点击拖拽,也不是很方便,如果能控制图片默认不展示那个大,更好调整,加载也快,关于这个设置默认值的源码没有配置,所以也是需要自己自定义配置并添加。

3.4.2 跟源码,找控制款高的代码

  • 根据入口跟源码,如下:
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

3.4.3 方法1:修改源码1处(在 image2.js 里更改)

3.4.3.1 添加宽高默认配置(代码1处 简单设置——初版)
  • 先从简单处随便设置一个数字看效果,如下:
    在这里插入图片描述
    在这里插入图片描述
  • 所以,可以在这里设置,但是如果写死的话,好像也不太好,所以还是配置的好些,继续吧……
3.4.3.2 添加宽高默认配置(代码1处 简单设置——优化1)
  • 代码如下:

    // 自定义配置项 image2_default_width名字自己起,和代码里的名字保持一致即可
    config.image2_default_width = 160;
    config.image2_default_height = 290;
    
    widthField.setValue( editor.config.image2_prefillDimensions === false ? 0 : editor.config.image2_default_width );
    heightField.setValue( editor.config.image2_prefillDimensions === false ? 0 : editor.config.image2_default_height );
    

    在这里插入图片描述

  • 效果如下:
    在这里插入图片描述

3.4.3.3 添加宽高默认配置(代码1处 简单设置——优化2)
  • 上面看着很完美了,但是还有个问题,得按着图片的比例缩放图片呀,自己设置一个款高默认值,图片很有可能变形,所以,需要找一个根据宽度的值计算高度,根据高度的值计算宽度的方法,这个源码里是有的,因为当你输入宽度 或 高度的时候,另一个值是自动计算出来的,那我们只需要拿来即用就行!
  • 先找到源码的计算规则,如下:
    在这里插入图片描述
  • 然后进行优化,优化代码如下:
    在这里插入图片描述
    /**
    * 优化: 
    * 1. 如果默认宽度配置了,直接计算默认高度,高度不再取默认值
    * 2. 如果默认高度配置了,直接计算默认宽度,宽度不取默认值
    * 3. 二者都配置的情况下,以配置宽度为主
    * 4. 二者都没有配置的情况下,取图片原始值
    */
    var image2_width = editor.config.image2_default_width;
    var image2_height = editor.config.image2_default_height;
    if(image2_width){image2_height = Math.round( height * ( image2_width / width ) );
    }else if(image2_height){image2_width = Math.round( width * ( image2_height / height ) );
    }else{image2_width = width;image2_height = height;
    }
    widthField.setValue( editor.config.image2_prefillDimensions === false ? 0 : image2_width );
    heightField.setValue( editor.config.image2_prefillDimensions === false ? 0 : image2_height );
    
  • 配置代码如下:
    /*** 自定义配置项 image2_default_width名字自己起,和代码里的名字保持一致即可* 可配置一个,配置两个的时候,以配置宽度优先*/
    config.image2_default_width = 190;
    config.image2_default_height = 290;
    
  • 效果,如下:
    在这里插入图片描述

3.4.4 方法2:修改源码2处(在 plugin.js 里更改)

3.4.4.1 说明
  • 如果在另外一处配置的话,如下:
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
3.4.4.2 在 plugin.js 中实现宽高默认配置(问题)
  • 在上面代码处可以设置,但是此处取不到 config.js 配置文件的值,需要把默认值写在 plugin.js 里,这样的话,如果想修改默认值还得翻来覆去,挺麻烦的,暂且不用此方式,可能有其他方法,如果各位童鞋有,可以交流!

4. 更多配置

  • 参考官网:
    https://ckeditor.com/docs/ckeditor4/latest/api/CKEDITOR_config.html.

这篇关于富文本编辑器CKEditor4简单使用-04(跟源码设置image2插件图片的默认宽高等相关配置)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/672949

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::