If you are not familiar with html then you will not be able to learn JavaScript since both html and JavaScript are closely bound together. Thus if html is strange to you then I suggest that you first go through the section on html and then return back here once you have mastered the art of creating web pages.
If you are familiar with both html and any other programming language then carry on because you will add another language to your repertoire. Also you may skip down to the header ‘A simple Payroll Programme’ since the next part which explains programming variables will already be familiar to you.
If you are familiar with html but have never programmed then read the next part very carefully because a thorough knowledge of programming variables and how they resemble and how they differ from algebraic variables is the basic building block of programming.
The manipulation of variables is at the heart of computer programming. To the non-programmer variables are associated with algebra. A typical algebraic problem would be as follows:
If x = 5, y = 9 and z=3, what is the value of 2x+3y-5z?
The solution to this of course is that if x is 5 then 2x is 10, if y is 9 then 3y is 27 and if z is 3 then 5z is 15. Thus the expression 2x+3y-5z equates to 10+27-15 which is 22.
We shall look at one more example of algebraic expression. In calculating a person’s pay we multiply the number of hours the person has worked with his hourly rate. Thus if a person has worked x hours and if his hourly rate is y, then his pay is xy. On a particular week if the person has worked 30 hours and if his rate is K8 per hour then we can state the problem as follows:
If x = 30 and y = 8, what is the value of xy?
In this case the solution is the same as above, i.e. if x is 30 and y is 8 then xy is 30 multiplied by 8, which is 240.
As stated earlier, programming a computer involves the manipulation of variables and they are manipulated in exactly the same way as they are manipulated in algebra. This means that we assign a value to each variable in the expression and then perform the calculation specified in that expression.
There are, however, a few differences between how we use variables in algebra and how we use them in programming. Some of the differences are as follows:
In algebra we use a single letter to denote a variable. The most common letters are x, y, z followed by a, b, c. In programming the names of the variables can be as long as we want them to be. Thus in our payroll example above, instead of If x = 30 and y = 8, what is the value of xy we would have the following: if hours = 30 and rate = 8, what is the value of hours * rate?
A computer programme would solve the problem as follows:
In algebra we assign only numeric values to variables and we don’t care whether they are integers or real numbers. In programming we must be more precise. We must specify whether a variable is to hold an integer or a real number
In algebra, variables represent only numeric values. In programming, however, variables can certainly represent numeric values, but they can also represent text and a variety of other objects such as data stored in databases etc. We need not concern ourselves with this use of variables until later in the course.
Events are things that happen. Rugby matches, rock concerts, film premiers and celebrities visiting are all examples of everyday events. In the area of programming we have already encountered an event when we used the hover pseudoclass to change the appearance of a button or any other object that the mouse hovered over. Anyone filling in a form either on a desktop application or on a web page creates any number of events. Some examples are:
Moving the control to a text box to enter text causes the onFocus event
Actually entering text in the box causes the onChange event of the same box
With the mouse you can cause the mouseDown, mouseMove mouseUp and mouseOver events. (The mouseOver event is similar to the CSS pseudoclass hover.)
Loading a web page causes the onLoad event.
And the list goes on.
In this exercise here we shall be using the same form we used in the previous example, except that now we shall be actually making it perform calculations for us. Our basic work plan is to manually enter the values for the hours worked and the hourly rate in the appropriate text boxes and then with our mouse click on the button we named ‘Button 1’. The mouse click will cause the click event of the button to occur which will run the code for calculating the values of the gross, tax and net and display those results in the appropriate text boxes.
Our modified web page is shown below in Listing 1. The <body> block is almost identical to the one we used in the previous section, i.e. it simply sets up the form with its labels, input boxes and a button. The big changes are in the <head> block. Here we have removed the styling to a .css file named JavaScriptStyles.css and in line 4 we have created a link to that file. The biggest change of all is that we have introduced a <script></script> which spans lines 7 – 19. Welcome to JavaScript!
We have just stated that the <body> block is almost identical to the previous version we encountered. The ‘almost’ is due to the fact that we have made a small, but very significant, change to line 46. Here we have added onClick=calculatePay() to the attributes of the button. The result of this is that when we click on that button the function calculatePay(), which spans lines 8 – 18 will run.
The code for calculatePay() is shown above in Listing 4. For a novice programmer there is a lot to learn in those lines. We shall begin with line 2 which we have reproduced below.
Starting at the left we have const sngHours. This is a variable. As its name implies it will hold the value of the number of hours a person has worked.
Where does it get this value from? There is an equal to sign after it. This indicates that it gets its value from whatever is to the right of the equal to sign.
There are a number of items to the right: parseFloat, document and getElementById.
The parseFloat is a function which converts a numeric data to floating point numbers and formats them with two decimal places
The document refers to the web page that is defined in Listing 1 above.
We have added a number of elements to this document:
A table along with its rows and cells
Five labels to which we gave the values of 'Hours Worked', 'Hourly Rate', 'Gross', 'Tax' and 'Net'.
Five input boxes to which we gave id’s of ‘Hours’, ‘Rate’, ‘Gross’, ‘Tax’ and ‘Net’.
In line 2 the function getElementById() is given the parameter of “Hours” This is equivalent to telling the system to look among all the elements of the web page and find the element whose id is “Hours”.
The .value at the end refers to the contents of the input box whose id is “Hours”, or in other words the value that the user entered into that input box.
Thus line 2 is equivalent to the statement 'Find the value of the element in the current document whose id is “Hours” and store that value in the variable sngHours.
Thus if the user entered 20 into the box for hours, then 20 will end up being stored in the variable sngHours.
In the same way line 3 is equivalent to the statement 'Find the value of the element in the current document whose id is “Rate” and store that value in the variable curRate.
Again if the user entered 25 in the box for rate then 25 will end up being stored in the variable curRate.
Thus by the time lines 2 and 3 are complete the variables sngHours and curRate 20 and 25 stored in them provided that that is what the user entered in the input boxes.
Once we have the values for the hours worked and the hourly rate we can commence calculating the gross, tax and nett.
We calculate the gross by multiplying the hours by the rate. This is done at line 4.
const curGross = sngHours * curRate;
This is very much like an algebraic equation and is equivalent to the statement 'Multiply the values stored in the variables sngHours and curRate and store the result in the variable curGross'.
Thus if sngHours had a value of 20 and curRate had a value of 25 then curGross would have a value of 20 multiplied by 25, which would be 500.
The tax is calculated at line 5
curTax = curGross * 0.25;
Again this is equivalent to saying 'Multiply the value stored in the variable curGross by 0.25 and store the result in curTax.'
Thus if curGross held a value of 500 then curTax would have a value of 125.
The net is calculated at line 6 by subtracting the value of the tax from the value of the gross.
const curNet=curGross – curTax;
This is equivalent to saying 'Subtract the value stored in curTax from the value stored in curGross and store the result in curNet.'
If curGross held a value of 500 and curTax a value of 125, then curNet would hold a value of 375.
Lines 7 – 9 work in the opposite direction to lines 2 – 6, in that they transfer values from the programme variables into the text boxes on the form. Thus line 8 can be read as transfer the value of the variable curGross into the input box in the current document whose id is “Gross” To put it another way the line is displaying the calculated value of the gross in the text box reserved for displaying the same gross.
Lines 8 and 9 can be explained in exactly the same way.
Looking at lines 2 – 9 in Listing 4 we can see at first glance that they form three groups:
Lines 2 and 3
Lines 4 – 6
Lines 7 – 9
The first group of lines, 2 and 3, take data from the form’s text boxes into the programme area. Since this group’s function is to take data into the programme area they are referred to as the input section of the programme.
The second group uses the data taken in by the input section to calculate the values of the gross tax and net. This is also referred to as processing the data. For this reason these group of lines are called the process section of the programme.
Lines 7 to 9 are involved in transferring copies of the data from the memory out to the form’s text boxes. For this reason they are referred to as the output section of the programme.
Every programme, regardless of size has these three sections in it. In fact in large complex programmes the input section itself can have its own input, process and output section. The same applies to the other two sections.
The above form is a working model of the one we have been discussing. Experiment with it by adding different values to hours and rate and then press the Calculate Pay button to perform the calculation.
The uploaded file provides an introductory guide to JavaScript programming, emphasizing its integration with HTML to create dynamic web applications. The document starts by establishing the importance of understanding HTML before delving into JavaScript, as the two technologies are closely intertwined. For beginners with no prior programming experience, the guide offers foundational insights into variables, events, and basic programming concepts, while also catering to experienced programmers looking to expand their skill set.
One of the key topics discussed is the concept of variables, which are described as the building blocks of programming. The file compares programming variables to algebraic variables, highlighting similarities and differences. It explains how variables in programming can represent various data types, including numeric values and text, and introduces basic mathematical operations and their application in programming scenarios such as payroll calculations.
The guide also explores the concept of events, which are actions or occurrences triggered by user interaction or system processes. Examples include mouse clicks, text input, and page loading. The document demonstrates how to handle events in JavaScript, with a particular focus on the onClick event used to execute functions like calculatePay(), which calculates gross, tax, and net pay based on user input.
A simple program example is provided to illustrate the integration of JavaScript with HTML. This program features a form with input fields for hours worked and hourly rate, as well as a button to calculate pay. The corresponding JavaScript function uses methods like document.getElementById() to retrieve user input and perform calculations. The process is explained in detail, covering input retrieval, data processing, and output display.
The file discusses the structure of programs, breaking them into three main sections: input, processing, and output. Each section's role is defined, and their interrelation is demonstrated using the payroll example. Input involves capturing user data, processing includes performing calculations, and output refers to displaying the results back to the user.
Additionally, the document touches on stylistic elements, such as external CSS files for styling forms and how these are linked to the HTML document. The narrative is complemented by code snippets and figures to provide practical examples, making the content accessible to readers.
Overall, the file offers a step-by-step introduction to JavaScript programming, with practical examples and detailed explanations that aim to build a strong foundational understanding of integrating JavaScript into web development projects.