First of all, I do not want to extend a class. I would ideally like to do this.
public function __construct() {
/* Set Framework Variable */
global $Five;
$this =& $Five;
}
I have a system where the variable $Five is a container class which contains other libraries. I could assign this to a local variable of Five… i.e.
public function __construct() {
/* Set Framework Variable */
global $Five;
$this->Five = $Five;
}
However, the reason why I am trying to avoid this is that function calls would be getting a little long.
$this->Five->load->library('library_name');
Its a little ugly. Far better would be.
$this->load->library('library_name');
What is the best solution for this?
I think that
is going to be your best option unless you decide to have the class extend the helper class. AKA
However, this means that
Helper_Classis instantiated every time you instantiate a class.Another method would be to have a pseudo-static class that assigned all of the helper classes to class members
Then just call it
If
$Fiveis a global, you could justglobal $Fiveeverytime you want to use it, but putting that at the top of every function just seems like bad coding.Also, I’d just like to do my public service announcement that Global variables are generally a bad idea, and you might want to search ‘Dependency Injection’ or alternative to globals. AKA
instead of
Globals rely on an outside variable to be present and already set, while dependency injection requests a variable that it is assuming to be an instance of the Five class.
If you are running PHP 5.1 (Thanks Gordon), you can insure the variable is an instance of the
FiveClassby doing this: