为了账号安全,请及时绑定邮箱和手机立即绑定

在 php 类中的对象中调用方法

在 php 类中的对象中调用方法

PHP
不负相思意 2022-01-14 17:18:44
我需要调用一个对象内部、类内部的函数。当然,对于“On The Fly”类方法,我可以使用 __call 和 __set 魔法来调用它,但在这种情况下不能。下面是这种情况的示例。class mainclass{public    $v1    = "Hello";public    $fn    = null;function    __construct( )    {    $this->fn    = (object) [ "fn1"   => null,                              "fn2"   => null,                              ];    }public  function __call( $name, array $args )    {    return  call_user_func_array( $this->$name, $args );    }public    function  fn3()    {    echo    "This of course works! <br />";    }}$main = new mainclass();$main->fn4  = function()    {    echo    "Even this works! <br />";      };$main->fn->fn1  = function()    {    echo    $this->v1 . " World :)";    };$main->fn3(); // This of course works!$main->fn4(); // Even this works!$main->fn->fn1(); //Call to undefined method stdClass::fn1() 有可能以这种方式调用函数“f1”: $main->fn->fn1() ?如果没有,有没有大刀阔斧的建议?不幸的是,这不是 JavaScript 并且不喜欢处理此类的方式,但我必须尝试一下
查看完整描述

3 回答

?
米琪卡哇伊

TA贡献1998条经验 获得超6个赞

对于这种情况,我唯一且简单的解决方法是更改匿名类中的对象。在此过程中,您必须使用类似的变量名称“$_this”将主类的范围存储在内部匿名类上。


class mainclass

{

public    $v1    = "Hello";

public    $fn    = null;



function    __construct( )

    {

    $this->fn    = new class( $this)

        {

        public $_this = null;

        public function __construct( $mainscope )

            {

            $this->_this =  &$mainscope;

            }


        public function __call( $method, array $args )

            {

            if  ( isset( $this->{ $method } )  )

                {

                return  call_user_func_array( $this->$method, $args );

                }

            elseif ( isset( $this->_this->{ $name } ) )

                {

                return call_user_func_array( $this->_this->{ $name }, $args);

                }

            }


        public function __set( $name, $value )

            {

            $this->{ $name } = is_callable( $value ) ? $value->bindTo( $this, $this ) : $value;

            }

        };

    }


public  function __call( $method, array $args )

    {

    return  call_user_func_array( $this->{ $method }, $args );

    }


public  function __set( $name, $value )

    {

    $this->{ $name }    = is_callable( $value ) ? $value->bindTo( $this, $this ) : $value;

    }


public    function  fn3()

    {

    echo    "This of course works! <br />";

    }

}



$main = new mainclass();


$main->fn4  = function()

    {

    echo    "Even this works! <br />";  

    };


$main->fn->fn1  = function()

    {

    echo    $this->_this->v1 . " World :)";

    };



$main->fn3(); // This of course works!

$main->fn4(); // Even this works!

$main->fn->fn1(); //Hello World :)

事实证明,它不是很丑陋,也可以管理。无论如何,这是目前唯一的选择。


查看完整回答
反对 回复 2022-01-14
?
忽然笑

TA贡献1806条经验 获得超5个赞

($main->fn->fn1)();应该工作。但是,您不能$this在匿名函数中访问


查看完整回答
反对 回复 2022-01-14
?
拉莫斯之舞

TA贡献1820条经验 获得超10个赞

$main->fn->fn1();

fn1是一个属性尝试使用$main->fn.


查看完整回答
反对 回复 2022-01-14
  • 3 回答
  • 0 关注
  • 204 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信