Yesterday we finished our IT websites, and mine is now available online at WebMun. This project ended up being a lot more work then planned and definitely our largest IT project of the year. Overall I'm quite happy with my website but there are many areas in which I could have improved throughout the process.
Criterion A - Investigation
My investigation and the creation of my actual website were nearly merged, in many aspects. I started off this unit by spending quite a long time looking at design 'principles' - what to do and what not do while creating websites. In the end, I think I spent too long on this considering I would later be limited by my own technological skills. Sure, it would in theory be great to have a custom 404 page, links that display properly in browsers for the blinds, clear headings and sub-headings that display perfectly across all web browsers. But when it came down to it many of these I simply did not have time for, or simply was not able to put in place. Most of people's knowledge about good web design comes in my opinion from themselves. I spend quite a lot of time on the internet and instead of spending a long time looking at what makes a good website, I could simply have thought about it. This would have given me more time to do the rest of my work.
After I looked at design, I started looking at coding languages themselves. I had done some programming before so I had a vague idea of the web languages I would need to investigate and get better at before actually starting my project: HTML I already knew, but I needed to practice CSS and particularly PHP, which allows for interactive websites. In many ways I think I spent too much time practicing these two languages by creating small pages that weren't directly useful to my final website, to just get myself going, than I really needed to. If I had started my website while practicing the languages, I would have managed to both get started on the website and practice.
The other thing that I did not spend enough time on during my investigation was looking up the actual topic of my website, MUN. I know quite a lot about MUN from personal experience but explaining it to other people was a completely different thing. Since I had a hard time with that, I ended up mostly linking to other websites explaining MUN in my final website. If I had read these articles beforehand, I might have been able to explain it in my own words, which would probably have been better for the wbesite as a whole.
My biggest issue during investigation was therefore time management. I knew we had a lot of time for this unit and I wanted to create a pretty ambitious website, that used technological skills I did not previously have. I ended up spending so much time "investigating" these languages that I did not have enough time left for the rest of my project.
Criterion B - Design
My main goal during the design stage was to keep the website simple and not do anything too groundbreaking. If there are going to be changes in web design, they'll occur slowly and it's not up to me to start a completely new trend. I think my website succeeded in that it was pretty simple and straightforward, but it would have been better to get it double-checked with others before starting to work on it. What really seemed obvious and simple to me might be impossible to understand for someone else, depending on what websites people are used to.
The part about my design that I was happy with, however, was that since I learned CSS before doing my design I knew what was possible and what was simply too hard. Having realistic expectations allowed me to make a design that was both possible to create and somewhat pleasant looking, and since I coded my own template I achieved pretty much my exact original design, instead of having to adapt to a ready-made template.
Knowing a little bit about programming languages from my investigation, I also wrote a to-do list of design specifications that was divided in priorities. This was really helpful for me while creating the website as it helped me manage my time better - instead of creating a handful of very pretty pages and then not having time for the rest of the website, I knew what had to be done before I could get into smaller details.
My design was pretty efficient but perhaps I should have thought more about the practicalities of creating such a design. It's very nice to only have to click two pages to get to the page you want, but practically with PHP this couldn't really be done...if I had done parts of my design after starting to create my website, I might have improved its feasibility.
Criterion C - Plan
My plan was pretty detailed in and out of itself and it sounded good on paper. As I moved forward, though, I realized it was completely unrealistic. Since I knew very little about PHP, it was impossible to plan how long creating each part of the website would take. I planned to create the login system in an hour - practically, it took me about 4 IT classes to get this done. It would have been hard to make a better plan, especially as few of the online tutorials tell you how long it will take to get this or this done. Programming can be very quick if everything goes according to plan, but it's hard to plan how long this or this will really take. I remember while creating one of the pages on my website I spent 30mn editing code and changing everything because it simply wasn't working. Eventually, I realized I had just forgotten a semi-colon. How can a plan prepare for this type of problems?
As I pretty quickly realized my plan was unrealistic, what I could have done is written a new one as I went along. Although you can't plan for every single problem, it's possible once you get coding to estimate about how much time each step will take. Instead I went without a compass and used my to-do list instead of an actual plan, which may not be the greatest idea time-management wise.
Criterion D - Create
Creating my website took much, much, much more time than I had planned. To be honest, I didn't really mind as it gave me the chance to learn PHP, a programming language I'd planned to learn for a long time but never gotten down to trying out. I learned a lot about programming and realized how little I really know about computers.
The first step of creating the website was to implement my design using CSS and HTML, two languages that are actually quite simple. Designing is quite forgiving: if you forget to put a sign here or there, chances are your website will still display correctly. With help from various websites, I was able to get my website's design up and running in about two evenings. It was a very fructuating part of the creation as you instantly get to see your designs and it doesn't get too long to put them up.
After designing my website started the hard part - getting it to "work". WebMUN was designed to be an interactive website, which I was abotu to find out just how hard it is to create. You can't simply type a page of information if you are going to let users contribute to your website. You need to create a page with a form in which the user can submit something, then a PHP script on another page to analyze that information, then another script to put it into a database (you first need to have that database set up, of course), then ANOTHER script to retrieve it from the database, another one to display the information and finally something to tell the user after they've submitted the first form.
I learned this as I went along and in the beginning, creating this code was very complicated as I did not remember the exact syntax of PHP. It's a pretty strict language - forget one character, write a double quote " instead of a single one ' and your whole page will not show. Troubleshooting was a very stressful process. It's annoying not to know why it's not working, and even more annoying when you find out it was just a small syntax error. On the bright side, it really helped me develop problem-solving skills. If a page wasn't working, I removed a chunk of code and saw if the website was still working - if it was, I removed an even smaller chuk until I had figured out exactly where the error came from. This idea of breaking a big problem into a smaller one is very present in programming but I think it can really help you think logically in other aspects of life.
As I got various parts of my website running, I think I developed many other good habits. The first that I told myself from the beginning was to never copy and paste codes from examples and tutorials, and instead type everything up myself. This seemed very redundant in the beginning and I nearly gave up on this resolution a few times. I was so happy to have written everything myself, though, when I came to the more complicated parts of my website. I was familiar with PHP and really understood it since I had always typed all the code myself, and it made it possible to go outside the boundaries of tutorials. It was easy to find explanations on "How to create a login system in PHP" but not quite so easy to find out "How to create an MUN-type debate system in PHP"....I was able to create that without a tutorial because I had learned PHP before.
The second good habit I took up during this project was never giving up on creating any type of web component. Sometimes it looked like the debating system or the voting system would never work, but once you start giving up on functions it all goes downhill- you start to give up on anything remotely complicated. It's better to have a website with a few fully-working functions than with stubs of many that you never get around to finishing.
The biggest issue with my website was probably navigation. My website ended up being very complex and navigation therefore also got much more complicated. I was spending so much time on getting things to work that I didn't have time to make sure it was clear to others how it worked. When I was nearly done with my website, I asked my friend what she would do when she got to the homepage. To me it was obvious I would click on the big "Join Now!" picture. Surprisingly, she said she would try clicking around the navigation bar, which was exactly what I DIDN'T want users doing as they were first supposed to register and login. Figuring out all the things users can do "wrong" was the hardest part of the website and the one I didn't spend enough time on as it's really what makes up navigation. I have a new found respect for programmers when I see all the work it takes to create just one small debate system. There are so many unknowns when users can click on just about any link! It probably would have helped if I had looked at more websites in the design stage.
Overall
In a contradictory way, I think my website would have been better if it had been smaller. I had limited time and making a smaller webpage would have allowed me to focus more on navigation and other issues, in order to have a perfectly working small website rather than a large, prototype one. I was a little overambitious, which is something I'm afraid I do quite often - I do not really take into account my time limitations and end up creating a large but imperfect product. This really is something I should think of in the future as a half-done job is not something I want to be doing in my DP years or college work.
Compared to my original design specifications, my website did not achieve all it was supposed to. Considering they were as I previously mentioned a little over-ambitious, that is not necessarily a bad thing but it does show me that I need to set myself realistic goals in the future. If from quite early on in the project you know you will most likely not achieve all of your goals, they become useless as you have no measure of how much you really plan to get done.
Design specifications
1. Information on MUN in general (debate procedures, researching tips, helpful links...) --- Yes. I wrote some of that information myself, but a lot of it was also linked from other websites.
2. Sign-up and login function --- Yes. This is something I spent quite a long time on adn it completely works.
3. A number of separate committees with sign-up functions for countries and chair positions --- Partly. Debate is enabled but there are no chairs and only the Security Council is fully working.
4. Real-time private chatrooms for each committee --- No. I realized this was not necessarily a needed function as the chances of there being enough delegates online at the same time to host a debate are quite slim.
5. Private chatroom and inboxing for the drafting of resolutions --- drafting of resolutions is enabled, but no private inboxing function.
6. Discussion pages for each forum with options such as "Speak for this resolution", "Speak against this resolution", "Submit an amendment", "Motion to..." to allow for delayed debating --- Yes. Delayed debating is nearly fully implemented.
7. Informal discussion forum for delegates to get to know each other --- A forum is present, but it is not really a "discussion space" so far.
8. Voting tool on each resolution --- Yes. This part is linked to an external website and consistenly works.
Overall, I'm still happy that I challenged myself as I learnt a lot throughout this unit. This was my favorite project of the year in IT and I think it's a nice conclusion to three years of technology as I really put together many elements we learnt throughout our units - how the web is changing (Web 2.0), internet ethics, how others are different from you, how to best pass along information...It followed on the Wikipedia unit where we started becoming active creators of the Web instead of passive observers. For me, this also gave me a different approach to websites I daily visit. Thinking of just how much work is behind Facebook or YouTube makes me dizzy. I also think it is important for teenagers to realize that there are limits to what is possible. We are at an age where we have dreams that are sometimes too big, and just seeing how much work an everyday product can be puts many things back into perspective.
In any case, the work of the webmaster is a never ending one and I think this unit really reminded me of the ever-changing nature of websites. When users are adding content, a website is constantly growing and interconnected to other websites. I hope I have time to improve WebMUN in the future as it is a project I am interested in and spent a lot of time on.
Subscribe to:
Post Comments (Atom)
Excellent, insightful evaluation! I will miss you at ISU.
ReplyDelete