WordPress 常用函数 / shortcode_atts
简介
将用户输入的短代码的属性值和短代码默认属性值合并,结果将包含所有已知属性的每个 key,他们的值是合并之后的结果。
用法
<?php shortcode_atts( $pairs , $atts ); ?>
参数
$pairs
(array) (required) 所有支持的属性和他们默认值的完整列表。
Default: None
$atts
(array) (required) 用户在短代码标签中输入的属性值
Default: None
返回值
(array)
用户输入和默认两者合并和过滤之后的列表。
实例
function antispambot_shortcode_handler($atts, $content='') {
extract( shortcode_atts( array(
'link' => '0'
), $atts ) );
if($link){
return '<a href="mailto:'.antispambot($content,1).'" title="mail to '.antispambot($content,0).'">'.antispambot($content,0).'</a>';
}else{
return antispambot( $content,0);
}
}
add_shortcode('email', 'antispambot_shortcode_handler');
上面代码创建了一个 ] ? çç??£ç ?¼?®æ?¯?一ä??属性: [[email link="1"]your-email@email.com ,这个属性是可选的,并且如果没有设置将使用默认值,这里使用 PHP 的 extract 函数是将合并之后的数组的每个 key 作为一个单独的变量更方便使用和访问,这里只有一个:$link,并且 shortcode_atts 函数完成调用之后,$atts 这个数组将不会被修改。
注解
$pairs 数据应该是短代码所有支持的属性的列表,返回的属性应该只在 $pairs 属性列表中的。
如果 $atts 列表中含有未被支持的属性,在最后返回的列表中将被忽略并被移除。
修改记录
Since: 2.5
源文件
wp-includes/shortcodes.php