Web Design and Programming - Assignment 1 Report
Web Design and Programming - Assignment 1 Report
Assignment One
Daniel Seal u3025958
This handbook details the construction of the Kangaroo University web site, beginning from the design and continuing to the final implementation of the product. This particular section will focus on the design stage.
Table of Contents
1. Information Architecture ................................................................................................................ 3 1.1 1.2 1.3 1.4 1.5 1.6 2. 2.1 2.2 2.3 2.4 2.5 3. 3.1 3.2 3.3 4. 4.1 The goal ................................................................................................................................... 3 The audience ........................................................................................................................... 3 The content ............................................................................................................................. 3 Visual presentation theme...................................................................................................... 4 Site map and navigation ......................................................................................................... 4 Visual forms ............................................................................................................................ 5 Unity ........................................................................................................................................ 6 Variety ..................................................................................................................................... 6 Focal point............................................................................................................................... 6 Contrast................................................................................................................................... 8 Visual balance ......................................................................................................................... 8 Keep the web experience free from mental difficulty .......................................................... 10 Ensure each click is a mindless task ...................................................................................... 11 Remove three quarters of the the words on each page ....................................................... 11 Explanation of the CSS rules ................................................................................................. 13 Element Selectors ......................................................................................................... 14 ID Selectors ................................................................................................................... 15 Class Selectors ............................................................................................................... 16 The difference CSS can make to the design of a page .................................................. 16
5. 6.
Implementation of Server-Side Code............................................................................................ 18 5.1 Comparison of ASP.Net and HTML code fragments ............................................................. 18 Explanation of the ASP.Net code fragment .................................................................................. 19 Program code .................................................................................................................................... 20 Program outputs .................................................................................. Error! Bookmark not defined.
Appendix ............................................................................................................................................... 20
1.
1.1
Information Architecture
The goal
The goal is to create a functional web site for the fictitious Kangaroo University. The purpose of the web site is to deliver information and services, via the World Wide Web, to those who are, or who wish to be, involved with the university. The design and implementation is of the upmost importance here. Whilst a content-rich web site is important, this handbook will not focus on the creation of countless web pages. The objective we are addressing here is that the theory of both web page design and programming is implemented using best practices. The task of creating many web pages does not matter. Now that the goal has been stated, lets move onto identifying the users who will visit the web site.
1.2
The audience
To identify who are the target audience, one easy way to do this is to look at who visits the brickand-mortar university in person. Obviously there are students, who go to university to obtain a higher education. Students are those who are currently studying at the university. It encompasses students studying a whole variety of qualifications, ranging from diplomas, bachelor degrees, masters and up to, and including, doctorates. To provide the necessary teaching, learning resources and research opportunities for the students, lecturers and tutors have to be included. Not to mention all the other employees too, such as the admin workers, maintenance team and security personnel. There are also prospective students who may be interested in studying at the uni, and most university campuses allow the general public to visit on-site. These visitors could be friends and relatives of a student, an employee or an interested third-party. After analysing all of the people involved with a university, we can classify them all into three distinctive groups: Students Staff Guests
Having identified the target audience, we must now decide what content will be included on the university web site.
1.3
The content
It was found that each audience group requirements differ in both their demands of functionality and information to be provided from the web site. Students will want to be able to enrol in a unit, find their timetable, and various other things. Guests, on the other hand, will want to be able to view the campus map.
Daniel Seal | u3025958 A lecturer or tutor may want to be able to answer a students question(s), post an announcement, view their pay information, and send requests for maintenance and various other tasks. Of course, there is some overlap of demands between users. Students and guests may both be interested in enrolling in a new course or unit. Students and tutors/lecturers will both want to be able to access their scheduled timetable. As a result, some demands could certainly apply to more than one user group. It is vital to determine whether a demand is unique to one group, or applies to a multitude of users.
1.4
The visual presentation theme is the global look and feel of the web site. It works as a template which applies a consistent design to all web pages.
1.5
The site map is relatively simple, as the goal was to design and implement a functional web site. It was never to create hundreds of web pages, like a real university web site. The advantage with linking only a small number of web pages to home page allows the structure to remain relatively simple, no matter how large the web site grows. Should the university require more web pages, they will simply be linked as subpages from the relevant section. The log in and register pages allows for the university to function with other technologies like blogs, forums, wikis, content management systems (CMS) and even social media.
Daniel Seal | u3025958 The separation of the log in and register pages furthermore allows the university to adopt to changes in technology, as the basis for registering and recording a person have remained intact for many centuries, despite the means of authentication.
Register
Students
Staff
This makes the web site quite easy to navigate. To further help the visitor, the home page link, title and breadcrumb navigation is employed universally throughout the web site. Regardless of the page theyre visiting, the user will always have a ample knowledge of where they are.
1.6
Visual forms
Now that the planning for the university have been finalised, it is time to focus on the visual design of the web site.
2.
2.1
Unity is an important factor to consider when designing a web site. It assures the visitor that they are on the same web site when they click on a link. It also keeps the respective information, within a page, in their same, predictable location for the user to read and interpret. To address unity within the page, all of the content and controls are centred in the middle with the background appearing on both the left and right-hand sides. More importantly, each page uses the exact same background image below.
The navigational links, title, log in and registration controls (utilities) and content are always arranged in the same position. As an example, the utilities component is always positioned at the top of every page. It will always be seen, no matter what web page the user is visiting.
In fact, with the exception of the home, virtually every page looks the same. There may been some variation in colour scheme and different images, however without these subtle variations, there would be no way to quickly and easily distinguish between each web page.
2.2
Variety
To maintain some variety, each section uses a slightly adjusted colour scheme and different images for the header. The home page also appears different to the lower level web pages. This is important as the home page serves as the launch pad to all site content. If the home page is fails to interest or entice the visitor to explore the web site deeper, then that is a potential loss of one customer.
2.3
Focal point
All web sites require something to focus on. The issue, however, it to ensure the most important information is interpreted first. Its what separates the memorable web sites from the good pile. By using a clear focal point, it helps to define what your web site is all about. It portrays to the visitor what the web sites intentions are and what content will be on the pages, at a quick glimpse.
To present the Kangaroo University as a unique web site, a background of kangaroos is positioned very prominently in the top-centre of the page. This immediately allows the visitor to make a distinction that this is the Kangaroo University, and not another higher-education institution.
Just below the background, the visitors eyes are then drawn to three distinct sections, with titles accompanying the related images. These are the three categories of the web site which leads the visitor to the relevant content. By using the images, the meaning of each title is more easily understood.
The log-in utility has been placed at the top, where the visitor can quickly log on. Although it is placed in a prominent position, it was vital that the kangaroo background theme and section links
Daniel Seal | u3025958 were clearly visible. As a result, the utilities are a shade darker. This means experienced visitors can still quicker log on, however the attention of a new visitor is not drawn to unnecessary information.
2.4
Contrast
It is important to consider contrast when designing a web site to ensure that the content is recognisable and understandable. Without adequate contrast, there is no point in designing the web site at all, as the visitor will not be able to distinguish and interpret the various shapes and text on the pages. Contrast is a particularly important factor when considering textual content. It is best to use high contrast to ensure that words are legible. A dark background and light foreground, for the text, is preferable, however the inverse of the two tones is still regarded as an effective use of contrast. As a result, for large bodies of text, it was better to use a white background with black coloured text. To contrast with the textual content, the titles and breadcrumb navigation use a black background with white text or, in the case of the links, pale-coloured text.
2.5
Visual balance
Visual balance helps the visitor to distinguish and interpret the relationship between objects, based on factors such as proximity, colour, tone and size. If one element is positioned closely to another, it is automatically considered to be related. If say, a huge element is positioned away from some smaller objects, the huge elements will be considered separate. This is what the kangaroo background achieves. It is positioned away from the utilities and navigational elements and thus it considered to be a separate entity. The elements that are the utilities however are positioned very closely together, which implies that they all relate to the same purpose. This allows the user to log on effortlessly without having to spot all of the components. The same applies to the sections of the web site. All three sections have been grouped together. The visitor does not have to tediously search on the home page, in frustration, to simply go to a different area of the web site. Everything is positioned in groups for easy dissection.
3.
Visitors typically navigate a web site differently to what the web designer would have envisioned. Instead of reading all of the text and making a well-thought out decision, visitors read a web page by scanning for keywords. The first relevant-sounding link is then clicked. If that page fails to deliver what theyre after, they will return back to the previous page. Should the visitor not be able to find the intended information, after a few tries of aimless navigation, they will abandon the web site and try a different one. The end result is losing customers to other competitors. To design a web site according to how visitors navigate the web, Steve Krug devised 3 Laws of Usability: Don't make me think. It doesn't matter how many times I have to click, as long as each click is a mindless, unambiguous choice. Get rid of half the words on each page, and then get rid of half of what's left.
As a result it is vital that web designers meet the above criteria, in order for the web site to be a success.
3.1
To answer the first law, the content on the Kangaroo web site must be easy to digest. The user must not feel threatened. This includes maintaining enough white-space, positioning images next to their related text, keep wording simple.
As explained earlier, the focal point allows the visitor to obtain a clear understanding of what the web site is all about
10
3.2
The second law is not so much about the number of clicking involved, but whether clicking links requires a high amount of concentration and thoughtful decision-making. If it is, the navigation system has been poorly designed. It is important to use clicking to break the information up into simple steps. This means making each click a purposeful action. For example, a user chooses to purchase an item online. If the user has to click each time to answer the next question, the entire process would take become too tedious and time-consuming. It can be dangerous if we oversimplify the process into too many steps. Instead, it is better to condense the online purchasing process into steps. Instead of countless page, the pages could well be condensed into five pages: Quantity and discounts Any other products? Payment details Order details Other products
Conversely, if the purchasing process was displayed all on one page, to the user, it would feel as though an avalanche of information had just pummelled them. When either compression or expansion of information is pushed too far, it is damaging to the usability of the web site. Basically its all about moderation. All content has been broken down into three sections: Students Guests Staff Members
From each section, the visitor can then find the content theyre looking for, depending on which section they clicked on. Additionally, in order to help the user locate which page they are at, breadcrumb navigation has been incorporated into the web site. This assures the user that they know exactly where they are located in the web site hierarchy.
3.3
The last law is there to prevent the text on pages from being too long. If the visitor has to continually scroll large amounts of text, they will most likely skip over whole paragraphs. Its bad enough that visitors skim read, we dont want them to completely ignore what you have to say.
11
To adhere to this law, the length of text has been kept to a minimum. The visitor does not have to scroll endlessly to read the content. Short titles have been employed to provide a quick glimpse of what each page is all about. Subtitles also separate large bodies of text to help the visitor quickly find the information they may be after on the page. Each page uses a restricted number of words. Everything has been kept to be as concise as possible and excessive scrolling has been avoided, by using lists and omitting unnecessary words.
12
4.
In order to implement the visual presentation theme, the best way to do so is to use styling language called Cascading StyleSheet (CSS). Whilst it is possible to code the visual design in HyperText Markup Language (HTML), CSS is far more flexible makes it easier to maintain. In essence, HTML is best used for the structure and content, and CSS is best used for presenting this content visually.
4.1
Now that CSS has been determined to be the best for presenting the visual design of web pages, it is time to look at the syntax of CSS and what it can achieve. The cascading stylesheet language, unlike HTML and XML, does not use angled brackets. Instead the CSS syntax looks more like a programming language, where the selector is declared and parameters are surrounded in curly brackets. Dont be fooled, however, into thinking that CSS and programming languages are the same. They are completely different and should be treated as such. There are three ways to implement CSS in a web page. The example of colouring a heading green is used to show the difference:  Inline  positioned inside the element.
<h1 style="color: green">This heading is green</h1>
index.html
<head> <link href="stylesheet.css" type="text/css" rel="stylesheet" /> </head>
13
Best used for styles used across the whole web site. 4.1.1 Element Selectors
To demonstrate how CSS can be used to style a page, lets alter the <body> element.
HTML Code
<html> <head> <title>Kangaroo University » Home</title> <link href="styles/main.css" rel="stylesheet" type="text/css" /> </head> <body> <!-- this CSS alters the <body> --> </body> </html>
The stylesheet above performs several modifications to the <body> element: 1. The margin on all sides is set to a size of zero pixels 2. The padding on all sides is set to zero pixels 3. Font changed to 11 point 4. The Arial font-family is set as the default to use. If the font is not installed on the users computer, try the next font
5. Background is changed to a black colour 6. A background image is used to complement the black colour 7. Background image is set to begin at the very top (vertical) and centred (horizontal) position 8. Background image is set to tile both horizontally and vertically across the page 9. Text alignment is changed from left (default) to a centred placement In the case of the Internet Explorer browser, child elements are also centred
10. Text colour is changed from black (default) to the colour white
14
4.1.2
ID Selectors
Now thats all well and good, however what if we only want to change the appearance of a specific element, but not when this element is used elsewhere. This is where the ID selector comes to the rescue. Instead of using the element name for the selector, the designer is free to choose their own name. The only requirement is that this hash symbol precedes the name and that the given name is not a reserved word. To apply the ID selector to the specific element, the id attribute has to be added to the corresponding HTML tag, in order for the ID to work its magic.
Styling a divider by ID
CSS Code
#theme { width: 860px1; height: 500px2; background: url('../images/bg-kangaroos.jpg') top left no-repeat3; display: block4; }
HTML Code
<div id="theme"> <! The kangaroo background theme will appear here --> </div>
The stylesheet above performs several modifications to the ID attribute called theme, which resides in the <div> element: 1. The width is set to 860px 2. The height is set to 500px 3. Background image is set to begin in the top left hand-corner and not tile 4. Turns the <div> into a fully-enclosed area of the set dimensions This ensures the background image is displayed
15
4.1.3
Class Selectors
The ID tag is quite a powerful selector when it comes to adjusting specific elements; however what happens if more than one element requires specialised styling. The answer to this problem is class selectors. Much like ID selectors, a symbol precedes the chosen class name. In case of class selectors, a full stop is used before the class name. A class attribute also has to be added into the HTML code, as demonstrated below.
HTML Code
<p class="disclaimer"> Kangaroo University, ACT 2601 Australia, Switchboard +61 2 6201 5111,  2011 Kangaroo University<br /> Australian Government Higher Education (CRICOS) Registered Provider numbers: Kangaroo University #00212K </p>
The stylesheet above performs several modifications to the class attribute called disclaimer, which resides in the <p> element: 1. Font-size changed to 9 point 2. Colour of the text is set to a very dark grey 3. Text is aligned to the centre
4.1.4
CSS can alter the visual presentation of pretty much anything on the web page. The two screenshots below demonstrate how a bland web page can be transformed into a more unique and attractive design:
16
CSS disabled
CSS enabled
17
5.
5.1
There are two ways to create ASP.Net controls. The first option is obvious: use ASP.Net syntax. The second option is to use Razor syntax. Unfortunately, the Razor syntax is only available with ASP.Net MVC3, so the following controls will be presented with the ASP.Net syntax.
Button
ASP.Net Code
<form runat="server" title="Form"> <asp:Button ID="myFirstButton" runat="server" Text="This is a button" /> </form>
Menu of hyperlinks
ASP.Net Code
<ul id="menu-container"> <li>
18
6.
As is depicted above, the dynamic ASP.Net code is converted into static HTML code when it arrives on the visitors web browser. The whole process is explained below: 1. Browser requests an ASP.Net file 2. Web server (i.e. ISS) forwards this request to the ASP.Net engine 3. Engine opens the requested ASP. Net file and reads it 4. ASP.Net file is executed, line by line 5. The file is passed back to the web server 6. The web server returns the ASP.Net file to the browser as plain HTML The reason why server-side languages are used so extensively on the web is that they present a large number of benefits including: To ability to create or alter content dynamically Hiding the source code away from prying eyes Easily customisable skins and themes Handle user queries or submitted data from forms Access databases and present the data inside
19
Appendix
Program code
main.css
html, body, p { margin: 0; padding: 0; } html, body { height: 100%; min-height: 100%; width: 100%; } html>body #content-container { height: auto; } html { cursor: default; } body { margin: 0; padding: 0; font: 11pt Arial, Helvetica, Tahoma, Verdana, sans-serif; background: #000 url('../Images/bg-backdrop.jpg') top center repeat; text-align: center; color: #fff; } h2, h3, h4, h5, h6 { clear: both; } p { margin-bottom: 1em; } #container { position: relative; min-width: 1127px; max-width: 1127px; width: 1127px; height: auto !important; height: 100%; margin: 0 auto; background: #000 url('../Images/bg-shading.jpg') top center repeat-y; text-align: center; } #content-container { width: 900px !important; width: 1127px; /* Fixes an IE width issue */ margin: 0 auto; text-align: center; } #main-layout { padding: 0 20px; background-color: #000; padding-bottom: 4em; width: 900px; /* Fixes an IE width issue */ max-width: 860px; /* Prevents standards-compliant browsers from overextending the width */ text-align: left; } #utilities { width: 860px; background: url('../Images/bg-utilities.jpg') top left repeat-x; margin: 0; padding: 0; padding: 10px 0; display: block; text-align: center;
20
21
22
.text-input { background: url('../Images/textfield.jpg') top left repeat-x; border: 0; } .clear-all { clear: both; }
index.html
<html> <head> <title>Kangaroo University » Home</title> <link href="styles/main.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="container"> <div id="content-container"> <div id="main-layout"> <div id="utilities"> <form> Username: <input type="text" class="text-input" name="username"> Password: <input type="text" class="text-input" name="password"> <input type="submit" value="Login"> <input type="button" value="Register"> </form> </div> <div id="header"> </div> <div id="content"> <div id="theme"> </div> <div id="site-sections"> <a href="students.html"><div class="site-section"> <div id="student-section-image" class="section-image" title="Image of students"></div> <div id="student-section-text" class="section-text">Students</div> </div></a> <a href="guests.html"><div class="site-section"> <div id="guest-section-image" class="section-image" title="Image of guests"></div> <div id="guest-section-text" class="section-text">Guests</div>
23
students.html
<html> <head> <title>Kangaroo University » Home</title> <link href="styles/main.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="container"> <div id="content-container"> <div id="main-layout"> <div id="utilities"> <form> Username: <input type="text" class="text-input" name="username"> Password: <input type="text" class="text-input" name="password"> <input type="submit" value="Login"> <input type="button" value="Register"> </form> </div> <div id="header"> <div id="site-sections"> <a href="students.html"><div class="site-section"> <div id="student-section-text" class="section-text">Students</div> </div></a> <a href="guests.html"><div class="site-section"> <div id="guest-section-text" class="section-text">Guests</div> </div></a>
24
25
guests.html
<html> <head> <title>Kangaroo University » Home</title> <link href="styles/main.css" rel="stylesheet" type="text/css" /> </head> <body>
26
<div id="container"> <div id="content-container"> <div id="main-layout"> <div id="utilities"> <form> Username: <input type="text" class="text-input" name="username"> Password: <input type="text" class="text-input" name="password"> <input type="submit" value="Login"> <input type="button" value="Register"> </form> </div> <div id="header"> <div id="site-sections"> <a href="students.html"><div class="site-section"> <div id="student-section-text" class="section-text">Students</div> </div></a> <a href="guests.html"><div class="site-section"> <div id="guest-section-text" class="section-text">Guests</div> </div></a> <a href="staff.html"><div class="site-section" id="last-site-section"> <div id="staff-section-text" class="section-text">Staff Members</div> </div></a> </div> <div id="breadcrumb"> <a href="index.html"><div id="logo"></div></a> <a href="index.html">Home</a> » Students </div> <h1>All visitors are welcome!</h1> </div> <div id="content"> <div id="guests-wrapper" class="wrapper"> <h2>The Kangaroo University</h2> <p>At the University of Canberra, Australias Capital University, our focus is on preparing you for a successful and rewarding career.</p> <p>We call it professional preparation for professional careers. And it works. Our graduates are consistently ranked among the most employable in Australia.</p> <p>To discover how the University of Canberra can help you fulfil your potential, I invite you to explore this site, visit the campus or contact one of my colleagues, whose details you will find on this website.</p> <p><strong>Professor Stephen Parker</strong><br /> <em>Vice-Chancellor and President</em></p> <h2>What do you want most from your time at University?</h2> <ul> <li>state of the art knowledge and skills in your chosen discipline</li> <li>professional preparation for a competitive edge in your chosen career</li>
27
staff.html
<html> <head> <title>Kangaroo University » Home</title> <link href="styles/main.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="container"> <div id="content-container"> <div id="main-layout"> <div id="utilities"> <form> Username: <input type="text" class="text-input" name="username"> Password: <input type="text" class="text-input" name="password">
28
29
30
31