wp_kses_hair_parse

函数
wp_kses_hair_parse ( $attr )
参数
  • (string) $attr Attribute list from HTML element to closing HTML element tag.
    Required:
返回值
  • (array|false) List of attributes found in $attr. Returns false on failure.
定义位置
相关方法
wp_kses_attr_parsewp_kses_hairwp_kses_attrwp_kses_datawp_kses_attr_check
引入
4.2.3
弃用
-

wp_kses_hair_parse: 这个函数用来解析一个HTML标签,并将其属性与内容分开。

从包含属性的字符串中建立一个属性列表。

不修改输入。 可能会返回””evil”” 输出。如果有意外的输入,返回false,而不是剥离东西。

基于 `wp_kses_hair()` 但不返回多维数组。

function wp_kses_hair_parse( $attr ) {
	if ( '' === $attr ) {
		return array();
	}

	// phpcs:disable Squiz.Strings.ConcatenationSpacing.PaddingFound -- don't remove regex indentation
	$regex =
		'(?:'
		.     '[_a-zA-Z][-_a-zA-Z0-9:.]*' // Attribute name.
		. '|'
		.     '[[?[^[]]+]]?'        // Shortcode in the name position implies unfiltered_html.
		. ')'
		. '(?:'               // Attribute value.
		.     's*=s*'       // All values begin with '='.
		.     '(?:'
		.         '"[^"]*"'   // Double-quoted.
		.     '|'
		.         "'[^']*'"   // Single-quoted.
		.     '|'
		.         '[^s"']+' // Non-quoted.
		.         '(?:s|$)'  // Must have a space.
		.     ')'
		. '|'
		.     '(?:s|$)'      // If attribute has no value, space is required.
		. ')'
		. 's*';              // Trailing space is optional except as mentioned above.
	// phpcs:enable

	// Although it is possible to reduce this procedure to a single regexp,
	// we must run that regexp twice to get exactly the expected result.

	$validation = "%^($regex)+$%";
	$extraction = "%$regex%";

	if ( 1 === preg_match( $validation, $attr ) ) {
		preg_match_all( $extraction, $attr, $attrarr );
		return $attrarr[0];
	} else {
		return false;
	}
}

常见问题

FAQs
查看更多 >