繁体   English   中英

如何在php中访问父变量

[英]how to access parent variables in php

我不知道是否曾经问过这个问题,但是我一直在寻找它,却什么也看不到。

我的问题如下:

我有两节课。 父类(Products.php)包含以下代码:

class Producto {
    protected $id;
    protected $producto;
    protected $descripcion;

//CONSTRUCT FUNCTION
    function __construct($id, $prod, $description){
        $this->id=$id;
        $this->producto=$prod;
        $this->descripcion=$description;

    }
    //THE NEXT TO METHODS LOOK FOR IN THE DATABASE AND UPDATE THE PROPERTIES VARIABLES
    public static function db_select_producto_by_id($mysqli,$id){
        $query="SELECT * FROM tb_productos WHERE id='$id' LIMIT 1";
        return Producto::db_select($mysqli,$query);
    }

    public static function db_select_producto_by_name($mysqli,$name){
        $query="SELECT * FROM tb_productos WHERE producto='$name' LIMIT 1";
        return Producto::db_select($mysqli,$query);
    }

    protected static function db_select($mysqli, $query)
    {
        $result = $mysqli->query($query);
            if($result->num_rows > 0)
            {
                 $row=$result->fetch_array(MYSQLI_ASSOC);
                 return new Producto($row['id'], $row['producto'], $row['descripcion']);
            }else
                 return new Producto(0, 'none', 'none');
    }

子类(Oferta.php)从Producto.php扩展而来,包含以下代码:

class Oferta extends Producto{

    protected $idOferta;
    protected $tipoOferta;
    protected $precioOferta;
    protected $descripcionOferta;


    function _construct($idOferta, $tipoOferta, $precioOferta, $descripcionOferta, $id,$prod,$descripcion){
        $this->idOferta=$idOferta;
        $this->tipoOferta=$tipoOferta;
        $this->precioOferta=$precioOferta;
        $this->descripcionOferta=$descripcionOferta;

        parent::__construct($id,$prod,$descripcion);
    }

    //METHODS THAT SELECT FROM THE DATABASE

    public static function db_oferta_by_ofertaId($mysqli, $idOferta)
    {
        $query="SELECT * FROM tb_ofertas WHERE id=".$idOferta;
        return self::db_select($mysqli, $query); 
    }

    public static function db_oferta_by_productoId($mysqli, $productoId)
    {
        $query="SELECT * FROM tb_ofertas WHERE idproducto=".$productoId;
        return self::db_select($mysqli, $query); 
    }


    protected static function db_select($mysqli, $query)
    {
        $result = $mysqli->query($query);
            if($result->num_rows > 0)
            {
                 $row=$result->fetch_array(MYSQLI_ASSOC);
//MY PROBLEM IS HERE, BECAUSE I WANT TO ACCESS THE THE PARENTS VARIABLES TO RETURN AN OFERTA CLASS READING ALL THE VALUES FROM THE DATABASE
                 $producto=parent::db_select_producto_by_id($mysqli,$row['idproducto']);
                 return new Oferta($row['id'], $row['tipooferta'], $row['preciooferta'], $row['descripcionoferta'], $producto->id, $producto->producto, $producto->descripcion);
            }else
                 return new Oferta(0, 'none', 'none', 'none', 'none', 'none', 'none');
    }

正如您从Oferta类的db_select方法中看到的那样,一旦我从数据库中读取了数据,就无法访​​问父级属性。 我会很感激任何解决方案,在此先感谢您

您可以通过在$ this对象上调用来访问扩展类的方法:

$this->db_select_producto_by_id($mysqli,$row['idproducto']);

上面写的代码是正确的,问题是我在Oferta类的构造函数中只有一个简单的下划线 构造函数的名称前需要两个下划线

Oferta的构造应如下所示:

function __construct($idOferta, $tipoOferta, $precioOferta, $descripcionOferta, $id,$prod,$descripcion){
    $this->idOferta=$idOferta;
    $this->tipoOferta=$tipoOferta;
    $this->precioOferta=$precioOferta;
    $this->descripcionOferta=$descripcionOferta;

    parent::__construct($id,$prod,$descripcion);
}

如您所见,现在该函数已正确编写。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM