Block validation: Block validation failed – Custom WordPress Gutenberg Block Fails In Editor when reloaded

huangapple go评论66阅读模式
英文:

Block validation: Block validation failed - Custom WordPress Gutenberg Block Fails In Editor when reloaded

问题

以下是您要翻译的内容:

I am very new to WordPress and I am very new to Gutenberg Blocks. I have created some simple blocks using the npm Gutenburg generator. In my package.json file I have created the following attributes in my package.json file

"attributes": {
	"quote": {
	  "type": "string"
	},
	"source": {
	  "type": "string"
	}
}

In my edit.js file I have the following block stucture

export default function Edit(props) {
	return (
		<div { ...useBlockProps() } className="testimonial">
			<div className="testimonial__wrapper">
				<div className="testimonial__header">
					<i className="testimonial__quote__left"></i>
					<RichText
						tagName="blockquote"
						value={props.attributes.quote}
						onChange={(content) => props.setAttributes({ quote: content })}
						placeholder='Enter Quote'
						keepPlaceholderOnFocus={true}
					/>
					<i className="testimonial__quote__right"></i>
					<RichText
						tagName="figcaption"
						value={props.attributes.source}
						onChange={(content) => props.setAttributes({source: content })}
						placeholder='Enter Quotee / Source'
						keepPlaceholderOnFocus={true}
					/>
				</div>
			</div>
		</div>
	);
}

and this is my save function in the save.js file

export default function save(props) {
	return (
		<div className="testimonial">
			<div className="testimonial__wrapper">
				<div className="testimonial__header">
					<i className="testimonial__quote__left"></i>
					<RichText.Content tagName="blockquote" value={ props.attributes.quote } />
					<i className="testimonial__quote__right"></i>
					<RichText.Content tagName="figcaption" value={ props.attributes.source } />
				</div>
			</div>
		</div>
	);
}

When I add my custom block into the editor it works great. Should I update and then view my page that includes the block it works! However should I refresh or reload the editor that contains my block I get the following error:

Block validation: Block validation failed for `create-block/einzweidinge-testimonial` ({name: 'create-block/einzweidinge-testimonial', icon: {...}, keywords: Array(0), attributes: {...}, providesContext: {...}, …}).

Content generated by `save` function:

<div class="testimonial"><div class="testimonial__wrapper"><div class="testimonial__header"><i class="testimonial__quote__left"></i><blockquote></blockquote><i class="testimonial__quote__right"></i><figcaption></figcaption></div></div></div>

Content retrieved from post body:

<div class="testimonial"><div class="testimonial__wrapper"><div class="testimonial__header"><i class="testimonial__quote__left"></i><blockquote>ffff</blockquote><i class="testimonial__quote__right"></i><figcaption>fffff</figcaption></div></div></div>

I have noticed that should I add a block and not input any data to the RichText components the validation error is not raised! I am not sure if this helps solve the issue but I also see the following warning in the console:

Block validation: Expected token of type `EndTag` ({type: 'EndTag', tagName: 'blockquote'}), instead saw `Chars` ({type: 'Chars', chars: 'ffff'}).

I am stumped here and unsure what I am doing wrong? I've been looking into this for a couple of hours! Any help or guidence would be appreciated.

** UPDATE **

When inspecting the error in the editor I have noticed that word press seems to add extra content - in this case p tags.

英文:

I am very new to WordPress and I am very new to Gutenberg Blocks. I have created some simple blocks using the npm Gutenburg generator. In my package.json file I have created the following attributes in my package.json file

&quot;attributes&quot;: {
	&quot;quote&quot;: {
	  &quot;type&quot;: &quot;string&quot;
	},
	&quot;source&quot;: {
	  &quot;type&quot;: &quot;string&quot;
	}
  }

In my edit.js file I have the following block stucture

export default function Edit(props) {
	return (
			&lt;div { ...useBlockProps() } className=&quot;testimonial&quot;&gt;
				&lt;div className=&quot;testimonial__wrapper&quot;&gt;
					&lt;div className=&quot;testimonial__header&quot;&gt;
						&lt;i className=&quot;testimonial__quote__left&quot;&gt;&lt;/i&gt;
							&lt;RichText
								tagName=&quot;blockquote&quot;
								value={props.attributes.quote}
								onChange={(content) =&gt; props.setAttributes({ quote: content })}
								placeholder=&#39;Enter Quote&#39;
								keepPlaceholderOnFocus={true}
							/&gt;
						&lt;i className=&quot;testimonial__quote__right&quot;&gt;&lt;/i&gt;
							&lt;RichText
								tagName=&quot;figcaption&quot;
								value={props.attributes.source}
								onChange={(content) =&gt; props.setAttributes({source: content })}
								placeholder=&#39;Enter Quotee / Source&#39;
								keepPlaceholderOnFocus={true}
							/&gt;
					&lt;/div&gt;
				&lt;/div&gt;
			&lt;/div&gt;
	);
}

and this is my save function in the save.js file

export default function save(props) {
	return (
		&lt;div className=&quot;testimonial&quot;&gt;
			&lt;div className=&quot;testimonial__wrapper&quot;&gt;
				&lt;div className=&quot;testimonial__header&quot;&gt;
					&lt;i className=&quot;testimonial__quote__left&quot;&gt;&lt;/i&gt;
					&lt;RichText.Content tagName=&quot;blockquote&quot; value={ props.attributes.quote } /&gt;
					&lt;i className=&quot;testimonial__quote__right&quot;&gt;&lt;/i&gt;
					&lt;RichText.Content tagName=&quot;figcaption&quot; value={ props.attributes.source } /&gt;
				&lt;/div&gt;
			&lt;/div&gt;
		&lt;/div&gt;
	);
}

When I add my custom block into the editor it works great. Should I update and then view my page that includes the block it works! However should I refresh or reload the editor that contains my block I get the following error:

Block validation: Block validation failed for `create-block/einzweidinge-testimonial` ({name: &#39;create-block/einzweidinge-testimonial&#39;, icon: {…}, keywords: Array(0), attributes: {…}, providesContext: {…},&#160;…}).

Content generated by `save` function:

&lt;div class=&quot;testimonial&quot;&gt;&lt;div class=&quot;testimonial__wrapper&quot;&gt;&lt;div class=&quot;testimonial__header&quot;&gt;&lt;i class=&quot;testimonial__quote__left&quot;&gt;&lt;/i&gt;&lt;blockquote&gt;&lt;/blockquote&gt;&lt;i class=&quot;testimonial__quote__right&quot;&gt;&lt;/i&gt;&lt;figcaption&gt;&lt;/figcaption&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;

Content retrieved from post body:

&lt;div class=&quot;testimonial&quot;&gt;&lt;div class=&quot;testimonial__wrapper&quot;&gt;&lt;div class=&quot;testimonial__header&quot;&gt;&lt;i class=&quot;testimonial__quote__left&quot;&gt;&lt;/i&gt;&lt;blockquote&gt;ffff&lt;/blockquote&gt;&lt;i class=&quot;testimonial__quote__right&quot;&gt;&lt;/i&gt;&lt;figcaption&gt;fffff&lt;/figcaption&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;

I have noticed that should I add a block and not input any data to the RichText components the validation error is not raised! I am not sure if this helps solve the issue but I also see the following warning in the console.

blocks.min.js?ver=69022aed79bfd45b3b1d:10 Block validation: Expected token of type `EndTag` ({type: &#39;EndTag&#39;, tagName: &#39;blockquote&#39;}), instead saw `Chars` ({type: &#39;Chars&#39;, chars: &#39;ffff&#39;}).

I am stumped here and unsure what I am doing wrong? I've been looking into this for a couple of hours! Any help or guidence would be appreciated.

** UPDATE **

When inspecting the error in the editor I have noticed that word press seems to add extra content - in this case p tags

Block validation: Block validation failed – Custom WordPress Gutenberg Block Fails In Editor when reloaded

答案1

得分: 1

问题已解决,问题出在我在package.json文件中定义了"attributes"对象,而不是block.json文件中!

英文:

I finally worked out the issue, the problem was that I was defining my "attributes" object in the package.json file and not the block.json file!

答案2

得分: 0

以下是您要翻译的内容:

问题在于如何定义您的属性;在使用RichText时,需要sourceselector以正确存储和渲染属性。

block.json

{
    ...
    &quot;attributes&quot;: {
        &quot;quote&quot;: {
            &quot;type&quot;: &quot;string&quot;,
            &quot;source&quot;: &quot;html&quot;,
            &quot;selector&quot;: &quot;blockquote&quot;
        },
        &quot;source&quot;: {
            &quot;type&quot;: &quot;string&quot;,
            &quot;source&quot;: &quot;html&quot;,
            &quot;selector&quot;: &quot;figcaption&quot;
        }
    }
}

在您的RichText组件中,tagName(例如,blockquote)可以用作属性值的选择器。您的save()edit()函数都已正确设置为RichText。但请注意,RichText上的keepPlaceholderOnFocus属性默认为true,并且已从RichText中移除,因此会在控制台中生成警告。一旦更新了属性,您的块应该会验证并按预期工作。

英文:

The issue is how your attributes are defined; a source and selector is required when using RichText to properly store and render the attributes.

block.json

{
    ...
    &quot;attributes&quot;: {
        &quot;quote&quot;: {
            &quot;type&quot;: &quot;string&quot;,
            &quot;source&quot;: &quot;html&quot;,
            &quot;selector&quot;: &quot;blockquote&quot;
        },
        &quot;source&quot;: {
            &quot;type&quot;: &quot;string&quot;,
            &quot;source&quot;: &quot;html&quot;,
            &quot;selector&quot;: &quot;figcaption&quot;
        }
    }
}

In your RichText component, the tagName (eg. blockquote) can be used as the selector for the attributes value. Both your save() and edit() functions are setup with RichText correctly. One note though, the property keepPlaceholderOnFocus on RichText will throw a warning in the console as its default is true and the property has since been removed from RichText. Once you have updated the attributes, your block should validate and work as expected.

huangapple
  • 本文由 发表于 2023年3月21日 01:41:11
  • 转载请务必保留本文链接:https://go.coder-hub.com/75793567-2.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定