In this lesson we shall be using a two dimensional array to store data about a construction firm' employees, their skills/qualifications and their current projects. This data is to be available online so that the firm's clients can also check up on the skills that the firm provides.
There are two parts to this project: building the user interface, which will be an online form, and designing and writing a program that can be queried from the form in order to provide answers for both management and clients.
We shall first examine the html code that spans lines 9 to 45. The <body> block consists entirely of a <form> element which spans lines 11 to 41.
At line 13 a <h4> header is created which is centered on the page and has the text "Search by Qualification". Lines 14 to 19 defines the combo box.
Line 14 defines the box by first giving it an id whose value is ‘qualification’ and whose onchange event calls the function searchData(). To this function it passes the parameters ‘qualification’ and 1. The first parameter is the id of the combo box so that searchData() will know which combo box called it. The second parameter is the number of the column that will be searched. The value of 1 means that searchData() will search for the value in the second column, i.e. the column that contains the job description of the workers.
The effect of the <option> tags that span lines 15 – 19 is to add the text between the opening and closing tags to the drop down list of the box.
Lines 21 to 40 define two other combo boxes but as the form of their definition is identical to the one we just described there is no need to discuss them.
Now it is time to look at the JavaScript code below.
Lines 1 to 10 are taken up with defining the two dimensional array arrStaff. It is built according to the layout shown below.
To reference any element of this array we have to use two index numbers, the row number and the column number. Thus arrStaff[3][4] would mean the value on row 3 of column 4, which would in this case be ‘Weltec’. Similarly arrStaff[5][1] would be ‘Roofer’.
The function searchData() which spans lines 11 to 56 is the second part of the code for this application. The function is passed two parameters, dataType and dataPosition. The first parameter, dataType is the id of the combo box that called the function and the second parameter is the column in the array where the function is to search. We shall follow this function through one set of processing from one combo box and with a specific value.
Supposing that the user selected the option ‘Roofer’ from the combo box that is defined at lines 14 to 20 of Listing 1, then the onchange attribute would call searchData() with the values ‘qualification’ and 1 in its parameters. Thus at line 13 the programme searches for the element whose id is ‘qualification’ and stores a pointer to that element in the variable e.
At line 14 the programme tests if e has a value of null, or in other words if there is an element on the page with an id of ‘qualifications’. If there is then the body of the if at line 15 is ignored and the else component at line 16 is executed. At lines 25 and 26 two variables intCounter and intCounter are initialised. The former will be used to determine which row of the table to search and the second will determine whether we have found the target or not.
The while loop which spans lines 20 to 26 uses the variables intCounter and blnFound to determine whether or not the value ‘Roofer’ exists in column 1, i.e. the second column, of our table. The loop iterates while the variable intCounter is less than the length of the two dimensional array arrStaff and the Boolean variable blnFound is false.
At line 22 the value of the variable e, i.e. ‘Roofer’ is tested against the value held in arrStaff[0][1]. This is the same as saying column 1 of row zero. As we can see from above this will give the value of ‘Carpenter’ – which is not what we are searching for. Consequently line 23 is skipped and line 25 is executed, thus incrementing intCounter to 1. The loop iterates again and this time column 1 of row 1 is tested.
This process continues until column 1 of row 5 is tested where we find the first match with ‘Roofer’. In this case the condition at line 22 will be true for the first time and thus the variable blnFound will be set to true. The loop will then terminate and control will pass to line 27.
Line 27 marks the start of the second part of the function searchData(). In the first part, i.e. lines 12 to 26, we were searching for a data item in the array arrStaff[]. By the time we get to line 27, then if blnFound is true we have found our target and lines 28 to 52 are involved in creating a web page and building up HTML code that creates a table to present our data inside that page
Line 29 creates a new window called myNewWindow with a width and height of 900 and 600 pixels respectively. Line 30 uses html code to create to create a web page inside that window with the same dimensions as the window itself and with a antique white coloured background.
Lines 31 – 33 create a banner for the page which in our case will be ‘Search results for Roofer’
Line 34 creates a table which will be centered on the page, having a white background and a thin black border.
Lines 42 and 43 put a heading row on the table in bold lettering with the values Name, Profession, Location, Qualification, Institution and Hourly Rate.
Having found its first target at row 5 of the table, the programme will now commence to print out the values of that row and any subsequent row that has ‘Roofer’ in column 1.
At line 37 is a while loop that iterates while intCounter is less than the length of the array arrStaff. This loop will search the table from the row value where the first instance of ‘Roofer’ was found as far as the final row. In our case intCounter has a value of 5 and thus the body of the loop will be entered. Line 39 tests if the value of e is the same as the value in row 5, column 1. Again this is the case since both have a value of ‘Roofer’. Control therefore goes into the body of the if, i.e. lines 41 – 46. In the new window these lines will write the equivalent of:
Once this html code is written into the new window intCounter would be incremented to 6 at line 56 and the loop would iterate once more. At line 47 the condition would be true again since the combo box and column 1 of row 6 would still have the same value. The details of Mike Jones would therefore be printed in the same format as those of John Smith.
The loop would iterate three more times but lines 49 – 54 would not be executed since there are no more Roofers in the table.
Thus once the loop terminates control goes to line 50 which finishes off the closing tab of the <table> and then line 51 finishes off the closing tabs of both the <body> block and of the <html> itself.
This is a live version of the form and you can try searching any group you wish. If you use 'Search by Qualification' and select 'Roofer', your output should be like the result below.
This document is an instructional resource on JavaScript arrays, focusing on their implementation in an application for querying data about construction workers. The content is structured into sections that cover learning outcomes, an introduction to the project, form creation, JavaScript code, and an interactive demonstration of the application.
The learning outcomes aim to familiarize readers with one-dimensional and two-dimensional arrays, using HTML forms (specifically drop-down lists) to query array contents, and creating new browser windows to display query results. These skills are applied in a practical context, managing data for a construction firm.
The introduction explains the project's purpose: an online interface to store and query employee data, including names, qualifications, and work locations. The system benefits both management and clients by making data easily accessible through a web interface. The project comprises two components: building the user interface as an HTML form and creating a JavaScript program to process queries.
The section on building the form details its structure and functionality. The form includes three drop-down lists for querying by qualification, name, or work location. These lists interact with the JavaScript code through the onchange event, which triggers a function to search specific columns in a two-dimensional array. Illustrations showcase the form’s visual elements, including the drop-down menus and the completed interface.
The JavaScript code section provides a comprehensive explanation of the programming logic. It introduces the arrays that store employee data, including names, skills, locations, qualifications, institutions, and hourly rates. The key function, searchData(), is explained step-by-step. It searches the data array based on the user’s selection, identifies matching records, and dynamically generates an HTML table displayed in a new browser window. The explanation includes code snippets and visual representations of the data structures.
Finally, the "View the Application" section provides a live demonstration of the form, allowing users to query data and see the results in action. An example of a query searching for "Roofers" illustrates the output, which includes employee details formatted in a table.
This document effectively integrates theoretical knowledge of JavaScript arrays with practical application development. It emphasizes clear explanations, supported by examples and interactive features, making it a valuable learning resource for understanding arrays and dynamic web programming.
Based on the instructional material provided in the uploaded file, complete the following assignment. Ensure you carefully read the questions and apply your understanding of JavaScript, HTML forms, and arrays.
Part 1: Theory
Answer the following questions based on your understanding of the JavaScript application and its implementation.
Explain the purpose of using a two-dimensional array in the project. Provide examples of how it simplifies data storage and querying.
Describe the role of the searchData() function. How does it process data from the drop-down lists?
Why is the onchange event used in the drop-down lists? Explain its importance in the application workflow.
Discuss how JavaScript dynamically generates HTML for displaying the search results. What are the key steps involved?
Explain the significance of using a new browser window to display results. What advantages does this approach offer?
Part 2: Practical Tasks
Complete the following tasks to reinforce your understanding of the material.
Create a simplified version of the form described in the project. Include drop-down lists for querying by employee name, qualification, and work location.
Write a JavaScript function to handle a search based on the selected qualification. The function should display matching results in an alert box instead of a new window.
Modify the provided arrStaff array to include additional fields such as "Years of Experience" and "Contact Number." Update the searchData() function to include these fields in the output.
Add a new feature to the application: a drop-down list for filtering employees by their hourly rate (e.g., below $30, $30-$35, above $35). Ensure your code integrates this feature seamlessly.
Test your implementation by creating a sample dataset of at least 5 employees. Provide screenshots of the form and the results displayed for various queries.
Part 3: Reflection
Write a short reflection (200-300 words) on what you learned from this assignment. Discuss the challenges you faced and how you overcame them. Highlight any new skills you acquired related to JavaScript arrays, dynamic web content, or user interface design.
Submission Guidelines
Please submit the following:
Your written answers for Part 1 in a document format.
HTML and JavaScript files for Part 2.
Screenshots demonstrating your implemented features and their functionality.
Your reflection for Part 3.
Ensure all code is well-commented and formatted. Submit your work by the specified deadline.