問題は、無名関数と別の関数を区別できないことです。そのため、はい、クロージャ(つまり、無名関数)を削除することは可能ですが、複数のクロージャが同じフィルタで同じ優先度で動作する場合は、選択する必要があります。 、それらをすべて削除するか、または1つだけ削除します(正確にどちらがわからない場合でも)。
私はあなたが投稿した@toscho回答の関数から高度に派生した関数を使用してそれらをすべて削除する方法を示します:
/**
* Remove an object filter.
*
* @param string $tag Hook name.
* @param string $class Class name. Use 'Closure' for anonymous functions.
* @param string|void $method Method name. Leave empty for anonymous functions.
* @param string|int|void $priority Priority
* @return void
*/
function remove_object_filter( $tag, $class, $method = NULL, $priority = NULL ) {
$filters = $GLOBALS['wp_filter'][ $tag ];
if ( empty ( $filters ) ) {
return;
}
foreach ( $filters as $p => $filter ) {
if ( ! is_null($priority) && ( (int) $priority !== (int) $p ) ) continue;
$remove = FALSE;
foreach ( $filter as $identifier => $function ) {
$function = $function['function'];
if (
is_array( $function )
&& (
is_a( $function[0], $class )
|| ( is_array( $function ) && $function[0] === $class )
)
) {
$remove = ( $method && ( $method === $function[1] ) );
} elseif ( $function instanceof Closure && $class === 'Closure' ) {
$remove = TRUE;
}
if ( $remove ) {
unset( $GLOBALS['wp_filter'][$tag][$p][$identifier] );
}
}
}
}
remove_object_filter
すべてのタイプのオブジェクトフィルター(静的クラスメソッド、動的オブジェクトメソッド、クロージャー)を削除できるため、関数の名前を変更しました。
$priority
引数はオプションですが、それは常に使用する必要があるクロージャを取り外すときに、ときので、それ以外の機能は、その優先順位でフィルタに追加された閉鎖、関係なく削除します $priority
省略され、ターゲットクラス/メソッドやクロージャを使用して、すべてのフィルタがあります削除されました。
使い方
// remove a static method
remove_object_filter( 'a_filter_hook', 'AClass', 'a_static_method', 10 );
// remove a dynamic method
remove_object_filter( 'a_filter_hook', 'AClass', 'a_dynamic_method', 10 );
// remove a closure
remove_object_filter( 'a_filter_hook', 'Closure', NULL, 10 );