Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Is it worth converting my functional JavaScript code to an object-oriented design?

I'm currently building a small web application that includes a fair amount of JavaScript. When I was prototyping the initial idea, I just hacked together a few functions to demonstrate how the application would eventually behave intending to go forward re-writing the JavaScript in an object-oriented nature.

Now that I'm getting into the implementation phase, I'm finding that creating object-oriented JavaScript for the sake of being object-oriented seems overkill - the project isn't likely to require any major modifications in the future that would warrant and object-oriented design. Instead, I'm finding that a set of concise, cohesive functions are working well.

So, with that said and with attempting to adhere to the KISS principle, when a set of functions are providing a suitable solution to a problem, are there any other reasons worth considering to convert my code into an object-oriented design?

like image 683
Tom Avatar asked Oct 06 '08 12:10

Tom


4 Answers

No, although I personally find OOP more tasty, it is a means to an end, and not an end in itself. There are many cases where procedural programming makes more sense than OOP, an converting for the sake of converting, could be, as you said, overkill.

like image 91
Vincent McNabb Avatar answered Nov 17 '22 23:11

Vincent McNabb


No, let it be and move forward - that is more productive in my view .

like image 35
Johan Bresler Avatar answered Nov 18 '22 01:11

Johan Bresler


If your code is well structured, well laid out, and well commented, and does the job that is required of it, then messing with it for any reason other then to add features is ill-advised.

While it might be nice to say that the program is nicely OOP etc, if it doesn't need to be changed to work then I would definetely leave it as it is.

If it aint broke, dont fidgit with it :)

like image 5
Jimoc Avatar answered Nov 17 '22 23:11

Jimoc


If this code is already implemented and won't require maintenance or - better yet - upgrades, stick with it. If you are going to implement it now and it could get complex, consider the OO approach.

Experience has shown me that it's pretty easy to write and maintain procedural code while complexity is low, but after a certain threshold it starts getting exponentially more difficult to increase complexity while using procedural programming, whereas OOP, although harder to begin, keeps complexity much more manageable.

Bottom line: if the task is simple enough or has already been implemented, keep it simple. If it might grow more complex, consider OOP.

like image 2
schonarth Avatar answered Nov 18 '22 01:11

schonarth