tinyMCE 第四章 (工具栏模式)

现代网页设计中对响应式布局的需求不断增加,尤其是在文本编辑器这样的交互密集型组件上,适应不同屏幕尺寸和用户操作习惯成为了开发者必须解决的问题。TinyMCE是一个广泛使用的Web富文本编辑器,它提供了多种工具栏模式以适配各种编辑场景。这篇文章将会深入讲解TinyMCE中toolbar_mode的配置选项,以及如何正确设置其它工具栏相关选项。

工具栏模式(toolbar_mode

当编辑器的宽度不足以显示所有工具栏按钮时,toolbar_mode配置项可以帮助我们管理和展示工具栏按钮。主要有四种模式:"floating"(浮动)、"sliding"(滑动)、"scrolling"(滚动)和"wrap"(换行)。每种模式在不同情景下都有其特定用途和优势。

浮动(floating

当你将toolbar_mode设置为浮动模式,同时编辑器宽度不足以容纳所有工具栏组时,多余的按钮会被移动到工具栏抽屉中。以下是一个浮动模式的配置实例:

javascript 复制代码
tinymce.init({
  selector: 'textarea',
  toolbar_mode: 'floating'
});

在这种模式下,被隐藏的按钮会在点击抽屉图标时以浮动架的形式出现。

滑动(sliding

滑动模式会将多出的工具栏按钮固定在编辑器第一个工具栏下方,当你点击工具栏抽屉图标时它们会显示出来:

javascript 复制代码
tinymce.init({
  selector: 'textarea',
  toolbar_mode: 'sliding'
});

滚动(scrolling

为触摸屏设备设计的滚动模式会保留工具栏上的按钮,但是超出部分将被隐藏起来。用户可以通过滚动工具栏来访问这些按钮,不过需要注意的是,这种模式也会在桌面设备上显示滚动条。

javascript 复制代码
tinymce.init({
  selector: 'textarea',
  toolbar_mode: 'scrolling'
});

换行(wrap

在换行模式下,多出的按钮将被放置在主工具栏下方的一个或多个额外工具栏上:

javascript 复制代码
tinymce.init({
  selector: 'textarea',
  toolbar_mode: 'wrap'
});

工具栏位置(toolbar_location

此选项用于设置工具栏及菜单栏的位置。默认情况下,它们位于内容区域的上方,但将此选项设置为bottom可以将它们移至内容区域的下方:

javascript 复制代码
tinymce.init({
  selector: 'textarea',
  toolbar_location: 'bottom'
});

粘性工具栏(toolbar_sticky)

开启粘性工具栏功能后,当用户下滑网页时,工具栏会固定在屏幕顶部,直到编辑器不再可见。

javascript 复制代码
tinymce.init({
  selector: 'textarea',
  toolbar_sticky: true
});

粘性工具栏偏移(toolbar_sticky_offset

当你的网站有固定在顶部的导航栏时,toolbar_sticky_offset可以帮助你设置工具栏与视口顶部或底部的偏移量(取决于toolbar_location的设置),允许TinyMCE工具栏在导航栏下方"dock":

javascript 复制代码
tinymce.init({
  selector: 'textarea',
  toolbar_sticky: true,
  toolbar_sticky_offset: 100
});
相关推荐
木斯佳3 分钟前
前端八股文面经大全:26届秋招滴滴校招前端一面面经-事件循环题解析
前端·状态模式
光影少年23 分钟前
react状态管理都有哪些及优缺点和应用场景
前端·react.js·前端框架
saber_andlibert2 小时前
TCMalloc底层实现
java·前端·网络
逍遥德2 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
冻感糕人~2 小时前
【珍藏必备】ReAct框架实战指南:从零开始构建AI智能体,让大模型学会思考与行动
java·前端·人工智能·react.js·大模型·就业·大模型学习
程序员agions2 小时前
2026年,“配置工程师“终于死绝了
前端·程序人生
alice--小文子2 小时前
cursor-mcp工具使用
java·服务器·前端
晚霞的不甘2 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
小迷糊的学习记录2 小时前
0.1 + 0.2 不等于 0.3
前端·javascript·面试
梦帮科技3 小时前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json