类文档

WP_Block_Parser_Frame

💡 云策文档标注

概述

WP_Block_Parser_Frame 是一个用于在解析过程中临时存储部分块的类,属于 WordPress 块解析器的一部分。它通过构造函数初始化对象属性,包括块对象和字节偏移信息。

关键要点

  • WP_Block_Parser_Frame 类用于在解析时保存部分块,支持块解析器的堆栈重建。
  • 类包含公共属性如 $block(块对象)、$token_start(令牌起始字节偏移)、$token_length(令牌长度)、$prev_offset(令牌结束后的字节偏移)和 $leading_html_start(前导 HTML 起始字节偏移)。
  • 构造函数 __construct 接受参数来设置这些属性,其中 $prev_offset 和 $leading_html_start 为可选参数,默认值基于其他参数计算。

代码示例

public function __construct( $block, $token_start, $token_length, $prev_offset = null, $leading_html_start = null ) {
	$this->block              = $block;
	$this->token_start        = $token_start;
	$this->token_length       = $token_length;
	$this->prev_offset        = isset( $prev_offset ) ? $prev_offset : $token_start + $token_length;
	$this->leading_html_start = $leading_html_start;
}

📄 原文内容

Class WP_Block_Parser_Frame

Description

Holds partial blocks in memory while parsing

Methods

Name Description
WP_Block_Parser_Frame::__construct Constructor

Source

class WP_Block_Parser_Frame {
	/**
	 * Full or partial block
	 *
	 * @since 5.0.0
	 * @var WP_Block_Parser_Block
	 */
	public $block;

	/**
	 * Byte offset into document for start of parse token
	 *
	 * @since 5.0.0
	 * @var int
	 */
	public $token_start;

	/**
	 * Byte length of entire parse token string
	 *
	 * @since 5.0.0
	 * @var int
	 */
	public $token_length;

	/**
	 * Byte offset into document for after parse token ends
	 * (used during reconstruction of stack into parse production)
	 *
	 * @since 5.0.0
	 * @var int
	 */
	public $prev_offset;

	/**
	 * Byte offset into document where leading HTML before token starts
	 *
	 * @since 5.0.0
	 * @var int
	 */
	public $leading_html_start;

	/**
	 * Constructor
	 *
	 * Will populate object properties from the provided arguments.
	 *
	 * @since 5.0.0
	 *
	 * @param WP_Block_Parser_Block $block              Full or partial block.
	 * @param int                   $token_start        Byte offset into document for start of parse token.
	 * @param int                   $token_length       Byte length of entire parse token string.
	 * @param int|null              $prev_offset        Optional. Byte offset into document for after parse token ends. Default null.
	 * @param int|null              $leading_html_start Optional. Byte offset into document where leading HTML before token starts.
	 *                                                  Default null.
	 */
	public function __construct( $block, $token_start, $token_length, $prev_offset = null, $leading_html_start = null ) {
		$this->block              = $block;
		$this->token_start        = $token_start;
		$this->token_length       = $token_length;
		$this->prev_offset        = isset( $prev_offset ) ? $prev_offset : $token_start + $token_length;
		$this->leading_html_start = $leading_html_start;
	}
}

Changelog

Version Description
5.0.0 Introduced.