- 快速入门
- Explore advanced topics
- Accessibility
- Editor control identifiers
- Annotations
- Editor events
- tinymce-AddOnManager
- Boilerplate content CSS
- Handle asynchronous image uploads
- tinymce-Annotator
- tinymce-FocusEvent
- Configuring callbacks for Comments 2-0
- Keyboard shortcuts
- tinymce-CommandEvent
- tinymce-FocusManager
- tinymce-WindowManager
- Toolbar buttons
- PHP image upload handler
- tinymce-ContentEvent
- tinymce-Formatter
- tinymce-dom-DomQuery
- Create a plugin for TinyMCE
- Security
- tinymce-Editor
- tinymce-NotificationManager
- tinymce-dom-DOMUtils
- Create a skin for TinyMCE
- Usage with module loaders
- tinymce-EditorCommands
- tinymce-Plugin
- tinymce-dom-ScriptLoader
- Create custom notifications
- TinyMCE plugin Yeoman generator
- tinymce-EditorManager
- tinymce-ProgressStateEvent
- tinymce-dom-BookmarkManager
- Editor command identifiers
- tinymce-Formatter
- tinymce-EditorObservable
- tinymce-ResizeEvent
- tinymce-dom-ControlSelection
- tinymce
- tinymce-Env
- tinymce-Shortcuts
- tinymce-dom-DomQuery
- tinymce-Event
- tinymce-Theme
- tinymce-dom-DOMUtils
- tinymce-UndoManager
- tinymce-dom-EventUtils
- tinymce-dom-RangeUtils
- tinymce-dom-ScriptLoader
- tinymce-dom-Selection
- tinymce-html-Schema
- tinymce-dom-Serializer
- tinymce-html-Serializer
- tinymce-util-I18n
- tinymce-dom-TreeWalker
- tinymce-html-Styles
- tinymce-util-JSON
- Cloud deployment of plugins Only
- tinymce-editor-ui-registry
- tinymce-html-Writer
- tinymce-util-JSONRequest
- Version compatibility reference
- Image & file upload options
- tinymce-geom-Rect
- tinymce-util-LocalStorage
- Configuration options reference
- Integration and setup options
- tinymce-html-DomParser
- tinymce-util-Observable
- tinymce-util-Observable
- Advanced editing behaviors
- JWT authentication setup
- tinymce-html-Entities
- tinymce-util-URI
- tinymce-util-Tools
- Content appearance options
- Localization options
- tinymce-html-Node
- tinymce-util-Color
- tinymce-util-XHR
- Content filtering options
- Spelling options
- tinymce-html-SaxParser
- tinymce-util-Delay
- Cloud deployment guide
- Content formatting options
- URL handling options
- tinymce-util-EventDispatcher
- Cloud deployment of editor & plugins
- Contribute to documentation
- Examples & demos
- Specify editor & plugin versions
- Contribute to TinyMCE development
- Basic example
- User interface options
- Case Change
- Checklist plugin
- Classic editor example
- Comments 2-0 Demo
- Custom formats example
- Custom menu item
- HTML5 formats example
- Valid elements example
- Custom toolbar button
- Format Painter
- Live example
- Embed rich media
- Full featured example
- Premium features
- Configure Enhanced Media Embed Server
- Server-side component installation
- Custom toolbar menu button
- Image tools example
- Accessibility checking
- Integrate Enhanced Media Embed Server
- Configure server-side components
- Custom toolbar split button
- Inline editor example
- Advanced source code editing
- Format Painter
- Troubleshoot server-side components
- Tiny Drive
- Local upload
- Case Change
- Get TinyMCE bugs fixed
- Professional support
- Distraction-free editor example
- Page Embed plugin
- Checking links as-you-type
- Mentions
- System requirements
- Basic local file picker
- Permanent Pen plugin
- Check Spelling As-You-Type
- Self-hosted file management
- Commenting & collaboration
- URL conversion example
- Adding custom dictionaries
- Page Embed plugin
- Cloud-based file management
- Checklist plugin
- Paste from Word
- Introduction & getting started
- Permanent Pen Plugin
- Advanced installation choices
- Logo & attribution requirements
- Basic setup
- Customizing the editor UI
- TinyMCE distraction-free editing mode
- Filtering TinyMCE content
- Setup inline editing mode
- Rails integration
- Get Support & FAQ
- Work with plugins to extend TinyMCE
- React integration
- Advanced Code Editor plugin
- Localize TinyMCE
- Integrate with other projects
- TinyMCE for Swing integration
- Advanced List plugin
- Code plugin
- Use multiple TinyMCE instances in a single page
- Angular 2+ integration
- Vue integration
- Anchor plugin
- Code Sample plugin
- Check spelling in TinyMCE
- Angular 1 integration
- WordPress integration
- Autolink plugin
- Color Picker plugin
- System requirements
- Bootstrap integration
- Migrating from TinyMCE 4-x to TinyMCE 5-0-
- Autoresize plugin
- Comments 2-0
- Uploading images and files
- Dojo integration
- TinyMCE Mobile
- Autosave plugin
- TinyMCE classic editing mode
- jQuery integration
- BBCode plugin
- Context Menu plugin
- KnockoutJS integration
- Add plugins to TinyMCE
- Case Change
- Directionality plugin
- Accessibility Checker plugin
- Character Map plugin
- Drive plugin
- Checklist plugin
- Emoticons plugin
- Format Painter
- Full Page plugin
- Full Screen plugin
- Link Checker plugin
- Help plugin
- Lists plugin
- Paste plugin
- Horizontal Rule plugin
- Media plugin
- Permanent Pen Plugin
- Table plugin
- Image plugin
- Enhanced Media Embed plugin
- PowerPaste plugin
- Template plugin
- User interface components
- Image Tools plugin
- Mentions plugin
- Preview plugin
- Text Color plugin
- Autocompleter
- Import CSS plugin
- MoxieManager plugin
- Print plugin
- Text Pattern plugin
- Context forms
- Insert Date/Time plugin
- Nonbreaking Space plugin
- Quick Toolbar plugin
- Spell Checker Pro plugin
- Context menu
- Legacy Output plugin
- Noneditable plugin
- Save plugin
- Table of Contents plugin
- Context toolbar
- Link plugin
- Page Break plugin
- Search and Replace plugin
- Visual Blocks plugin
- Custom sidebar
- Page Embed plugin
- Spell Checker plugin
- Visual Characters plugin
- Dialog
- Tab Focus plugin
- Word Count plugin
- Dialog components
- Quick start
- Custom menu items
- Toolbar buttons
- Types of toolbar buttons
Table plugin
The table
plugin adds table management functionality to TinyMCE. It also adds a new menubar item Table
with various options in its dropdown including Insert table
and options to modify cells, rows and columns, and a toolbar button with the same functionality.
Type: String
Example
tinymce.init({
plugins: "table",
menubar: "table",
toolbar: "table tabledelete | tableprops tablerowprops tablecellprops | tableinsertrowbefore tableinsertrowafter tabledeleterow | tableinsertcolbefore tableinsertcolafter tabledeletecol
"
});
Config Options
These settings affect the execution of the table
plugin and let you modify the default styles and attributes for tables, preset class lists, and table behavior.
table_toolbar
This option allows you to specify the buttons and the order that they will appear on within TinyMCE’s inline contextual toolbar for tables. To specify the controls that should appear on TinyMCE’s table toolbar, the table_toolbar
option should be provided with a space separated list of toolbar controls. To create groups within this list, please add |
pipe characters between the groups of controls that you would like to create. If you want to disable this toolbar simply set the value to an empty string.
Type: String
Default Value: "tableprops tabledelete | tableinsertrowbefore tableinsertrowafter tabledeleterow | tableinsertcolbefore tableinsertcolafter tabledeletecol"
Possible Values: table
, tablerowprops
, tablecellprops
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
table_toolbar: "tableprops tabledelete | tableinsertrowbefore tableinsertrowafter tabledeleterow | tableinsertcolbefore tableinsertcolafter tabledeletecol"
});
table_appearance_options
This option allows you to disable some of the options available to a user when inserting or editing a table. When set to false
the following fields will not appear: Cell spacing, Cell padding, Border and Caption.
Type: Boolean
Default Value: true
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
table_appearance_options: false
});
table_clone_elements
This option enables you to specify which elements should be cloned as empty children when inserting rows/columns to a table. By default it will clone these “strong
em
b
i
span
font
h1
h2
h3
h4
h5
h6
p
div
” into new cells.
Type: String
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
table_clone_elements: "strong em a"
});
table_grid
This option allows you disable the table grid feature of the table menu. The grid feature (which is enabled by default) consists of a dragable matrix that a user can interact with to automatically create a table of x-rows by x-columns based upon their input. However, if you set this option to false
the dragable matrix will be replaced with a table dialog box into which a user can enter various parameters to create a table cols, rows, width, height, cell spacing, cell padding, border, caption and alignment). There are also advanced style options available in the dialog.
Type: Boolean
Default Value: true
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_grid: false
});
table_tab_navigation
This option enables you to disable the default tab between table cells feature. By default, when a user presses tab the cursor will move between cells within the table. By setting the table_tab_navigation
value to false
the cursor will tab between browser elements (such as the URL bar or form fields, etc).
Type: Boolean
Default Value: true
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_tab_navigation: false
});
table_default_attributes
This option enables you to specify default attributes for inserted tables.
Type: Object
Default Value: { border: '1' }
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_default_attributes: {
border: '1'
}
});
table_default_styles
This option enables you to specify the default styles for inserted tables.
Type: Object
Default Value: { 'border-collapse': 'collapse', 'width': '100%' }
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_default_styles: {
width: '50%'
}
});
table_responsive_width
This option enables you to force pixels or percentage sizes for tables. Setting this to true will force resizing by percentages and setting this to false will force pixel resizing. The default is to automatically detect what the table size is and just use that unit for resizing.
Type: Boolean
Default Value: none
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_responsive_width: false
});
table_class_list
This option enables you to specify a list of classes to present in the table options dialog box. This is useful if you want users to assign predefined classes to table elements.
Type: Array
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_class_list: [
{title: 'None', value: ''},
{title: 'Dog', value: 'dog'},
{title: 'Cat', value: 'cat'}
]
});
table_cell_class_list
This option enables you to specify a list of classes to present in the table cell options dialog box. This is useful if you want users to assign predefined classes to table cells.
Type: Array
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_cell_class_list: [
{title: 'None', value: ''},
{title: 'Dog', value: 'dog'},
{title: 'Cat', value: 'cat'}
]
});
table_row_class_list
This option enables you to specify a list of classes to present in the table row options dialog. This is useful if you want users to assign predefined classes to table rows.
Type: Array
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_row_class_list: [
{title: 'None', value: ''},
{title: 'Dog', value: 'dog'},
{title: 'Cat', value: 'cat'}
]
});
table_advtab
This option makes it possible to disable the advanced tab in the table dialog box. The advanced tab allows a user to input style
, border color
and background color
values.
Type: Boolean
Default Value: true
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_advtab: false
});
table_cell_advtab
This option makes it possible to disable the advanced tab in the table cell dialog box. The advanced tab allows a user to input style
, border color
and background color
values.
Type: Boolean
Default Value: true
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_cell_advtab: false
});
table_row_advtab
This option makes it possible to disable the advanced tab in the table row dialog box. The advanced tab allows a user to input style
, border color
and background color
values.
Type: Boolean
Default Value: true
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_row_advtab: false
});
table_resize_bars
This option makes it possible to disable the ability to resize table columns and rows by dragging the border between two columns or rows.
Type: Boolean
Default Value: true
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_resize_bars: false
});
table_style_by_css
This option enables you to force Table Properties dialog to use HTML5/CSS3 standards for setting cell spacing and cellpadding. By default, these are added as attributes to the table element. By setting this to true, cell spacing is applied to the table element as a border-spacing
style and cell padding is applied to all td
elements as a padding
style
Type: Boolean
Default Value: false
Possible Values: true
, false
Example
tinymce.init({
selector: "textarea", // change this value according to your HTML
plugins: "table",
menubar: "table",
toolbar: "table",
table_style_by_css: false
});
Examples of various table setups
Here are some examples of configuration for common setups.
No default attributes or styles on tables
tinymce.init({
plugins: "table",
table_default_attributes: {},
table_default_styles: {}
});
Pixel based resizing
tinymce.init({
plugins: "table",
table_default_attributes: {},
table_default_styles: {},
table_responsive_width: false
});
Percentage based resizing
tinymce.init({
plugins: "table",
table_default_attributes: {
'border': '1'
},
table_default_styles: {
'border-collapse': 'collapse',
'width': '100%'
},
table_responsive_width: true
});
Note: The advanced tabs of the table, row, and cell properties dialogs use the
colorpicker
to allow for border and background colors to be applied. See docs to use and configure a custom colorpicker.
Commands
Name | Description |
---|---|
mceInsertTable | Open the table properties dialog. On submit, a table will be inserted at the current cursor location. |
mceTableProps | Open the table properties dialog |
mceTableRowProps | Open the table row properties dialog |
mceTableCellProps | Open the table cell properties dialog |
mceTableSplitCells | Split the currently selected cell |
mceTableMergeCells | Merge the currently selected cells |
mceTableInsertRowBefore | Insert a row before the currently selected row(s) |
mceTableInsertRowAfter | Insert a row after the currently selected row(s) |
mceTableInsertColBefore | Insert a column before the currently selected column(s) |
mceTableInsertColAfter | Insert a column after the currently selected column(s) |
mceTableDeleteCol | Delete the currently selected column(s) |
mceTableDeleteRow | Delete the currently selected row(s) |
mceTableCutRow | Cut the currently selected row(s) to the clipboard |
mceTableCopyRow | Copy the currently selected row(s) to the clipboard |
mceTablePasteRowBefore | Paste any cut or coped rows into the table before the currently selected row(s) |
mceTablePasteRowAfter | Paste any cut or coped rows into the table after the currently selected row(s) |
mceTableDelete | Delete the currently selected table |
Example
tinymce.execCommand('mceInsertTable');
API
Name | Arguments | Description |
---|---|---|
insertTable | columns: number, rows: number | Insert a table with the given number of columns and rows at the current cursor location |
getClipboardRows | Returns the data for any rows cut or copied using mceTableCutRow or mceTableCopyRow | |
setClipboardRows | rows: HTMLElement[] | Set the data to be used by mceTablePasteRowBefore or mceTablePasteRowAfter for pasting rows into a table |
Example
tinymce.activeEditor.plugins.table.insertTable(2, 3);
Events
Name | Description |
---|---|
newrow | Fired when a row is created |
newcell | Fired when a cell is created |
ObectResizeStart | Fired when a resize action is started on a table, row, column or cell using the resize bars |
ObjectResized | Fired when a resize action is finished on a table, row, column or cell using the resize bars |
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论