本文内容主要参考海拔科技以及Gutenberg 开发API,介绍并解读新版WordPress所采用的 Gutenberg 编辑器 ( Block Editor/块编辑器 )如何创建自定义编辑块,包括块的样式以及扩展工具栏等。
本文适用于WordPress 5.22。关于WordPress Gutenberg自定义系列目录如下:
本文内容主要根据 Gutenberg 开发API ,为上文 WordPress之Gutenberg(古腾堡)自定义块(一) 中的js代码做解读,让大家更了解自定义的构建。
基本结构
利用wp.blocks.registerBlockType('namespace/block-name', {})
来构建一个新的自定义块,基本格式如下:
blocks.registerBlockType('namespace/block-name', {
title: '',
category: ''
icon: {},
description: '',
attributes: {},
edit: function(props) {},
save: function(props) {}
});
属性说明
- namespace/block-name:自定义块的名称,其中namespace是插件或主题的名称
- title:自定义块显示名称
- category:所在分类目录,可选为“ common 、formatting 、layout 、widgets 、embed ”,对应分别是:常用区块、格式、布局元素、小工具、嵌入
- icon:显示的图标
- description:描述文字
- attributes:自定义属性,用于保存属性值
- edit:编辑时调用的函数,返回一个编辑时的html格式
- save:保存时调用的函数,返回一个最后呈现的html格式
图标(icon)
输入值为 String 或者 Object
当属性值为 String 时, 可以是任何WordPress的Dashicons, 也可以是自定义svg元素。
// Specifying a dashicon for the block
icon: 'book-alt',
// Specifying a custom svg for the block
icon: <svg viewBox="0 0 24 24" xmlns="<a href="http://www.w3.org/2000/svg">http://www.w3.org/2000/svg</a>"><path fill="none" d="M0 0h24v24H0V0z" /><path d="M19 13H5v-2h14v2z" /></svg>,
当属性值是Object时,如上所述,图标应该包含在src属性中。除了src之外,对象可以包含背景和前景色,例如:
icon: {
// 背景色
background: '#7e70af',
// 前景色
foreground: '#fff',
// 图标属性
src: 'book-alt',
} ,
属性(attributes)
用attribute从标记中提取属性的值。最简单的一个例子如下:
{
url: {
type: 'string',
}
}
url就相当于一个字符变量,可以在自定义块中调用。在edit和save中,可以利用props.attributes.url
调用url值,利用props.setAttributes( { url: value } );
设置url值。注意:type只能是 null 、 boolean 、 object 、 array 、 number 、 string 、 integer 。
作为提取属性的值,需要加入source(内容来源)和selector(过滤器)两个属性。这个根据不同的需要而相应改变,可以详细阅读 Gutenberg 开发API :Attributes。这里提供三个常用的例子。
//例子1,提取块html中<code>标签内的内容到content中,返回值是字符串形式
content: {
type: 'string',
source: 'html',
selector: 'code',
},
//例子2,提取块中<span>标签内容到content中,返回值是数组形式
content: {
type: 'array',
source: 'children',
selector: 'span',
},
//例子3,提取包含类名为lan的类,用于提取某个标签的类。
typeClass: {
source: 'attribute',
selector: '.lan',
attribute: 'class',
},
函数 edit 和 save
edit 函数在编辑器的上下文中描述块的结构,显示编辑器在使用块时将呈现的内容。save函数定义了将不同属性组合到最终标记中的方式,表示块在网站前面的显示方式。 所以函数返回内容都应该是标准的HTML格式。如:
edit: function() {
return wp.element.createElement(
'div',
null,
'Your block.'
);
}
save: function() {
return wp.element.createElement(
'div',
null,
'Your block.'
);
}
这个需要根据自己的需求来构建不同的显示内容,本文主要根据上文《 WordPress之Gutenberg(古腾堡)自定义块(一) 》的js代码中主要的内容进行解析。
- 参数 props
props相当于该自定义块的数据结构,包含了之前定义的 attributes 内的各属性值,也有创建的函数。 - wp.element.createElement( )
这个与HTML的document.createElement( )
函数相似,常见用法如wp.element.createElement( 'nodename', { className: 'classname' }, content)
。nodename为元素名;classname为css类名,该部分可以添加各种属性值,如button的onClick
事件等;content为内容,可以为 Document 对象或者空值等。需要在php中引入js文件的array()
中添加'wp-element'
。 - wp.editor.RichText
简单说是wp特有的文本编辑, 需要在php中引入js文件的array()
中添加'wp-editor'
。
主要属性有:- value:内容
- onChange:内容改变时调用的函数
- placeholder:提示内容
- multiline:每一行添加的标签名,可选
- tagName:全部内容的标签名,可选
- wp.element.Fragment
使其子元素没有任何包装元素的组件。 - wp.editor.BlockControls
当块的edit
实现返回时,呈现图标按钮的工具栏。此部分可以阅读 wordpress / editor 关于 BlockControls 的介绍。 - wp.editor.AlignmentToolbar
AlignmentToolbar
需要为BlockControls
元素的子元素,作为块的文本对齐的预配置组件。
总结
自定义块想实现单一的样式功能并不困难,将想要的样式通过css导入,在js文件中将编辑内容save在一个带有你css相应类的标签中即可。想要实现复杂的样式功能,则需要块的扩展以及工具栏等自定义内容了。关于块扩展以及自定义工具栏可以阅读《 WordPress之Gutenberg(古腾堡)自定义块扩展栏》、《WordPress之Gutenberg(古腾堡)自定义块工具栏 》。