Welcome to my site

Post statistics

PHP __auoload

PHP5 reared it’s head mid 2004, 5 long years ago and all PHP developers rejoiced. Especially me. It gave us lots of new shiny tools to play with, including the obvious improved OO support and my particular favourite: the __autoload function.

For all you Java developers out there you know that you never have to include or require files, the Java language instinctively knows where to find them thanks to the compiler. So with the release of PHP5 I was thrilled to be able to do this—including every file you need is a real pain and takes precious time when developing.

There will be people out there saying that you shouldn’t use __autoload as it makes your application run slower. However, as computers have become so fast now, in my opinion, this becomes a moot point. Everything is all about maintainability, nowadays. If it saves me 5 hours in development time and 20 hours a year maintenance time I’m a happy man. I would also like to point out that includes_once is far, far more expensive than a simple include, which is what you people who do not use __autoload will have to do at some point. So the performance evens out.

I digress. This is supposed to be a quick guide, so let’s take our shoes and socks off and dive right in.

So what is this __autoload I speak of? Whenever you try and call a class that does not exist the function is triggered, giving you an opportunity to find the class, include it, and then tries to perform the class call for the second time. The perfect place for the __autoload is in your generic header file, so before any class has been called. So your header might look something like:

<?php
session_start();
include $_SERVER['DOCUMENT_ROOT']
  . '/library/autoload.function.php';
?>

The __autoload file simply contains 1 function. No classes, just 1 function.

<?php
function __autoload($className) {
    // Our code to go here
}
?>

So now we somehow need to dynamically include our class whenver this function is called. The generally accepted way is to name your class with reference to its location in the file structure. So let’s assume we have all our PHP classes in the library folder split into 3 further folders called Model, Controller and View. If we had a formatting class that we wanted to place in the Model directory, then we would name the class Model_Format.

When we try and instantiate this class, new Model_Format(), it will trigger the __autoload function which will be passed 1 parameter, the $className variable which in this case is Model_Format. So we now need to try and find out where the file is and include it before the script dies on us. We can easily do this by changing the underscore to a forward slash which gives us the class location. So our __autoload will look like:

<?php
function __autoload($className) {
    include $_SERVER['DOCUMENT_ROOT']
      . '/library/'
      . str_replace('_', '/', $className)
      . '.class.php';
}
?>

And there we have it, no need to ever include a class file again! You can of course extend the function to use some form of error checking or exception handing, in fact it is strongly recommended. Hope that saves you many an hour whilst debugging.

Date posted July 12th, 2009
Comments Disabled
Categories PHP
Author Christopher Hill

I'm Christopher. A twenty-something graduate, star gazer, aspiring triathlete, vegetarian, reader and writer, cinemaniac and lover of life in general

From the journal

From the deep

Obligatory links

Create simple UML diagrams on-the-fly

yUML is an online tool for creating and publishing simple UML diagrams. It’s makes it really easy for you to: Embed UML diagrams in blogs, emails and wikis, Post UML diagrams in forums and blog comments, Use directly within your web based bug tracking tool and Copy and paste UML diagrams into MS Word documents and Powerpoint presentations.

Javascript Tidy

One thing I often need to do is to tidy javascript from it’s packed state. Often to fix the developers bugs, add new features or to modify it slightly. I give you, the Javascript Tidy, a tool I couldn’t live without.

jQuery Slider plugin (Safari style)

A pretty awesome slider. Haven’t tried it out yet but the new version seems pretty easy to skin, so you can style it however-the-hell you want (note: click the ‘jQuery Slider update’ link).

MySQL Format Date

MySQL Format Date helps you format your dates using the MySQL DATE_FORMAT function. Just select a common date format and then change it to your suit your needs. The MySQL DATE_FORMAT code will be generated at the bottom of the page which you can then copy into your query.

The future of wireframes?

I have a love hate relationship with wireframes. In the last 10 years they’ve been a part of every web project I’ve worked on. There have been times when I can’t imagine how we would have solved a particular problem without them. Yet there are also times when I’ve been completely exasperated at the amount of time and energy they’ve consumed, seemingly to very little reward.

So you need a typeface?

A pretty humorous look into how you could choose your typeface for your next project.

New global visual language for BBC

We decided to embark on an ambitious project, called Global Visual Language 2.0, with the aim of unifying the visual and interaction design of bbc.co.uk and the mobile website.

jQuery plugin: Nivo Slider

A really cool image slider than has some unique transitional effects without using Flash.

MooTools plugin: DatePicker

jQuery has the best functioning plugins. MooTools has the best looking plugins. Whenever I want to add in a datepicker I always find this and think: “Oooh. Pretty. Do want.”. Then realise it’s MooTools only. Real shame.

jQuery plugin: Sparklines

I know, I know. This plugin has been around for, what seems like, years. But I thought I would give it a little bit of a spotlight. And yes, so I can easily find it again.

jQuery plugin: asmSelect

asmSelect is a jQuery plugin providing progressive enhancement to select multiple form elements. It provides a simpler alternative with several advantages. This new version includes several bug fixes and enhancements.

How coupon codes can lead to lost revenue

In this post we’ll be looking at how coupon codes (used synonymously here with promo and discount codes) can cause retailers to lose revenue. I’ll share some (hopefully) interesting trends that I’m seeing with a client I work with, and hopefully start a discussion with how to turn lost revenue into gained revenue.

A good browser should be able to reproduce itself

This is an interesting project which aimes to completely reproduce the visual aspect of Safari in pure HTML+CSS with zero images. There are a few caveats at the moment, such as no refresh button, but they say they are working on it. Once again this really shows the power that HTML5 and CSS3 brings to the Web.

jQuery plugin: gameQuery

gameQuery is a jQuery plug-in to help make javascript game development easier by adding some simple game-related classes. It’s still in an early stage of development and may change a lot in future versions.

CSS/Javascript Word Clock

A lit­tle ex­per­i­ment I built: a word clock using CSS3 trans­forms and a lit­tle Javascript to run the ac­tu­al clock. Use­ful? Maybe not. Fun? Def­i­nite­ly.

CSS Border Radius Web Page

It’s one of those things that makes you think “Doh! I should have made that agaes ago”. A simple Web page that allows you to simply get the CSS for the exact border radius you want.

The main thing is not to install Flash

A security expert who has won the Pwn2Own contest for 2 years running said, basically, that Flash is insecure. Well, we all knew that which is why we add Flashblock and the like. Right?

Pure CSS3 Bokeh effect

One of the best apps made using CSS3, that’s for sure. A few more options would be nice, such as changing colours of the circles and being able to place them manually.

EZ-CSS: An easy to use, lightweight, CSS framework

It is light (1kb), flexible, browser-friendly and easy to use! ez-css is a different kind of CSS framework. Authors are not bound to a “grid”. Plus, columns and gutters can be of any width.

jQuery plugin: Quicksand

I love Mac apps, especially for their attention to detail. CoreAnimation makes it so easy to create useful and eye-pleasing effects. Quicksand aims at providing a similar experience for users on the web.