Thanks.
I've been working on just writing what I need to get a certain job done and making things simple and generic. That seems to be helping me not get too overwhelmed with writing every possible bit of code under the sun.

I started with a simple Manager & ManagerHome system (someone was coaching me through the basics) but I think I will add a ManagerDao and a ManagerGateway. I've heard of "one click one action" and I'm starting to think that OO has kind of a "one function one action" phylosophy. I'll check out the link when his site comes back up though. Thanks

Joelle

Nando wrote:
Joelle,

It can take a while to get your head wrapped around OO. If you haven't read any introductory books, i'd definitely start there. That said, once you begin to understand the theory of it, you'll need to figure out how to practically apply it, and specifically in CF.

My number one tip is to keep your feet firmly on the ground. Stay practical. It's easy to imagine all kinds of Objects in your problem domain in the beginning and wonder how they are all related. Composition, Inheritance, Has A, Is A ... Managers may own (have) Projects and Projects have Managers and Workers and Managers have Workers and Workers have Managers AND Assignments. How the hell do you model THAT??? It seems like a tangled mess.

Stay on the ground and take it one step at a time. When your application is editing a Project, is it editing a Manager /at the same time? /If the answer is no, then you most likely don't need to build that relationship into your model. Especially when you are just beginning. Use a Gateway Object (ManagerGateway) to fetch the Manager Names and ID's for your form, and take that foreign key and use your ProjectDAO to persist it in your database.

So for this little piece of your app, where you edit/add Projects, i'd use these objects:

Project - a bean to hold and pass around your Project data

ManagerGateway - a gateway object that just returns queries ...

ProjectDAO - an object specifically for persisting Projects to the database, with CRUD methods create, read, update, and delete.

There are more sophisticated approaches, but this would be a simple outline to follow to get you started. Beans, Gateways, and DAO's.

You would get the data for your reports from a Gateway. In essence, a Gateway simply wraps your queries in a function and makes it available to your whole application from one place.

AssignmentGateway.cfc could have a theoretical method called "getMyReport()" that returns a query that joins your Worker, Manager, and Assignment tables with an appropriate where clause. getMyReport could also take an argument, or several arguments (similar to passing an attribute into a custom tag) that modify the where clause of your query.

Joe Reinhart has some excellent tutorials on OO in CF on his site, http://clearsoftware.net/ (once he gets it back up again - you'll need to wait a day or so ... ).


----------------------------------------------------------
You are subscribed to cfcdev. To unsubscribe, send an email to 
[email protected] with the words 'unsubscribe cfcdev' as the subject of the 
email.

CFCDev is run by CFCZone (www.cfczone.org) and supported by CFXHosting 
(www.cfxhosting.com).

An archive of the CFCDev list is available at 
www.mail-archive.com/[email protected]


Reply via email to