$this
ในฐานะที่เป็นข้อผิดพลาดที่ระบุว่าคุณต้องอินสแตนซ์ของระดับชั้นที่จะใช้ มีความเป็นไปได้อย่างน้อยสามประการ:
ทำให้ทุกอย่างคงที่
class My_Plugin
{
private static $var = 'foo';
static function foo()
{
return self::$var; // never echo or print in a shortcode!
}
}
add_shortcode( 'baztag', array( 'My_Plugin', 'foo' ) );
แต่นั่นไม่ใช่ OOP จริงอีกต่อไปเพียงแค่ตั้งชื่อ
สร้างวัตถุจริงก่อน
class My_Plugin
{
private $var = 'foo';
public function foo()
{
return $this->var; // never echo or print in a shortcode!
}
}
$My_Plugin = new My_Plugin;
add_shortcode( 'baztag', array( $My_Plugin, 'foo' ) );
สิ่งนี้…ใช้ได้ผล แต่คุณพบปัญหาบางอย่างคลุมเครือหากใครต้องการแทนที่รหัสย่อ
ดังนั้นเพิ่มวิธีการเพื่อให้อินสแตนซ์ของคลาส:
final class My_Plugin
{
private $var = 'foo';
public function __construct()
{
add_filter( 'get_my_plugin_instance', [ $this, 'get_instance' ] );
}
public function get_instance()
{
return $this; // return the object
}
public function foo()
{
return $this->var; // never echo or print in a shortcode!
}
}
add_shortcode( 'baztag', [ new My_Plugin, 'foo' ] );
ตอนนี้เมื่อมีคนต้องการได้รับวัตถุเช่นเขา / เธอก็ต้องเขียน:
$shortcode_handler = apply_filters( 'get_my_plugin_instance', NULL );
if ( is_a( $shortcode_handler, 'My_Plugin ' ) )
{
// do something with that instance.
}
โซลูชันเก่า: สร้างวัตถุในชั้นเรียนของคุณ
class My_Plugin
{
private $var = 'foo';
protected static $instance = NULL;
public static function get_instance()
{
// create an object
NULL === self::$instance and self::$instance = new self;
return self::$instance; // return the object
}
public function foo()
{
return $this->var; // never echo or print in a shortcode!
}
}
add_shortcode( 'baztag', array( My_Plugin::get_instance(), 'foo' ) );
static
ให้ฟังก์ชั่น