- 资源介绍
- 更新记录
- 安装教程
大多WordPress站长都表示用不习惯古腾堡编辑器,甚至在WordPress的商店里评分还是负数,但是我个人还是挺喜欢用这个编辑器的。比起之前那个大型富文本输入框,这种编辑器可谓即优雅又实用。
但这只是个开始,个人认为,能够有效的自定义模块,才是古腾堡编辑器最有优势的地方。
关于古腾堡编辑器,官方之前给了一个初步的文档,但是那个文档是以插件化为教程进行的,对于主题设计者而言,更希望在自己的主题里直接加入古腾堡自定义模块比较方便,因此本文的方向是在主题里直接往古腾堡编辑器里插入自定义模块。
今天我们来了解下如何给古腾堡编辑器添加自定义模块。
加载古腾堡自定义模板
//加载古腾堡自定义模板
function my_gutenberg_block(){
//注册古腾堡编辑器
wp_register_script( \'block-js\', get_template_directory_uri() . \'/extends/src/blocks.js\', array(\'wp-blocks\', \'wp-element\', \'wp-editor\', \'wp-i18n\'), \'1.0.0\' );
//插入模块
//fishtheme/block可自定义, 比如: demo/block
register_block_type( \'fishtheme/block\', array(
\'editor_script\' => \'block-js\'
) );
}
add_action( \'init\', \'my_gutenberg_block\' );
新建blocks.js
在目前使用的WordPress主题目录下,新建一个src的文件夹,并新建blocks.js。
blocks.js文件路径可以自定义,注意把上面代码里的对应路径也改一下就行。
编辑blocks.js
这个是古腾堡核心文件,基本所有的功能都在这里。
//js代码
//引入对应方法, 需要注意的是这里引用了4个方法, 那么在底部也需要window.wp.回调这4个方法
//这4个方法的来源是functions.php里的wp_register_script时array()里传入, 需要注意一一对应
(function (blocks, element, editor, i18n) {
var el = element.createElement; //用于输出HTML
var RichText = editor.RichText; //用于获取文本输入块
blocks.registerBlockType(\’gutenberg-examples/example-03-editable\’, {
title: \’测试模块\’, //标题
icon: \’universal-access-alt\’, //图标
category: \’layout\’, //对应栏目
attributes: { //模块的属性
content: {
type: \’array\’,
source: \’children\’,
selector: \’p\’,
},
},
//编辑时
edit: function (props) {
//获取模块输入的值
var content = props.attributes.content;
//点击输入框时用的方法
function onChangeContent(newContent) {
//将输入框里的内容输出到模块属性里
props.setAttributes({ content: newContent });
}
//返回HTML
//el的方法格式为: el( 对象, 属性, 值 ); 可以相互嵌套
//例如:
// el(
// \’div\’,
// {
// className: \’demo-class\’,
// },
// \’DEMO数据\’
// );
// 输出为: <div class=\”demo-class\”>DEMO数据</div>
return el(
RichText,
{
tagName: \’p\’,
className: props.className,
onChange: onChangeContent,
value: content,
}
);
},
//保存时
save: function (props) {
//保存时返回的HTML
return el(RichText.Content, {
tagName: \’p\’, value: props.attributes.content,
});
},
});
}(
window.wp.blocks,
window.wp.element,
window.wp.editor,
window.wp.i18n
));
查看效果
以上步骤完成后,在编辑器页面刷新,然后添加区块,看看是不是添加成功了。
此为官网提供的demo,如果想更深一步的开发自己需要的复杂的模块,请直接参考文章开始的《Block Editor Handbook》。
文章来自大资源网https://www.dzy10.com转载请注明出处,并保留本链接,谢谢!
猜你喜欢
-
WordPressPostType(自定义文章类型)功能介绍
2020-06-08 -
WordPress美化ripro主题美化_新年/高考/节日倒计时代码(小工具)
2020-06-08 -
WordPress成为针对SEO结果表现最好的CMS
2020-06-03 -
多站点配置的详细方法(站群建设)
2020-06-03 -
wordpress主题css适配屏幕尺寸大小自适应教程
2020-06-08 -
WordPress搬家更换域名或者批量数据库修改字符的方法
2020-06-08 -
WordPress如何添加用户自定义上传头像功能
2020-06-08 -
WordPress优化技巧用代码实现自动为文章添加标签
2020-06-08 -
WordPress获取文章统计数量及评论数量
2020-06-08 -
WordPress根据分类别名或ID选择内容页模板
2020-06-08
-
WordPress自动为新文章添加已使用过的标签
2020-06-08 -
WordPress实现前台登录功能
2020-06-08 -
WordPress搜索结果排除指定页面/文章/自定义分类
2020-06-08 -
如何优化图像以提高WordPress网站的加载速度?
2020-06-03 -
WordPress美化教程_为文章内容页添加展开收缩功能
2020-06-08 -
WordPress主题美化教程_浏览器右边多色滚动条
2020-06-08 -
WordPress如何禁止后台编辑主题和插件
2020-06-07 -
ripro如何添加css显示图?
2020-07-02 -
WordPress自动截取部分文章内容做为文章摘要
2020-06-08 -
WordPress实现上传文件自动重命名的两种方法
2020-06-08
猜你在找
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 大资源
- 2020-06-08Hi,初次和大家见面了,请多关照!
最后编辑:2020-10-20



