How To Make a Typing Tutor Project in JavaScript

How To Make a Typing Tutor Project in JavaScript

In this tutorial, we will show you the procedure of developing the Typing Tutor Project in JavaScript.

how to make a Typing Tutor Code in JavaScript
Figure: Files Required to develop a Typing Tutor Code in JavaScript

The interface of Typing Tutor

How To develop a Typing Tutor Project code in JavaScript
Figure: Interface of Typing Tutor

First file: index.html

<!DOCTYPE html>
<html lang="en">
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="English TT">
<meta name="author" content="Usama Siddiqui">
<meta name="Keyword" content="">
<title>Online Free Typing Tutor</title>
<!-- Bootstrap Core CSS -->
<link href="" rel="stylesheet">
<link href="css/style.css" rel="stylesheet">
<link href="" rel="stylesheet" type="text/css">
<link href="css/animate.css" rel="stylesheet" type="text/css">
<link href=',300' rel='stylesheet' type='text/css'>
<link href="css/online.css" type="text/css" rel="stylesheet">
<script src="js/glow.js"></script>

<!-- HTML5 Shim and Respond.js IE8 support of HTML5 elements and media queries -->
<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
<!--[if lt IE 9]>
<script src=""></script>
<script src=""></script>


<!-- Navigation -->
<nav class="navbar navbar-default navbar-custom">
<div class="container-fluid top-head">

<div class="navbar-header page-scroll">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<a class="navbar-brand" href="index.html">Free Typing Master</a>

<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
<ul class="nav navbar-nav navbar-right">
<li><a href="about.html"><p>About</p></a></li>
<li><a href="contact.html">Contact</a></li>
<li><a href="contact.html">Login</a></li>

<!-- /.navbar-collapse -->
<!-- /.container -->

<!-- Page Header -->

<header class="intro-header" style="">
<div class="container">
<div class="row">
<div class="col-md-8 Main-header">
<div class="site-heading">
<h1 class="t-name heading" id="online" data-text="Online Typing Tutor">English Typing Tutor</h1>
<h2 class="heading-text-h2"> A Best and Free way to Learn typing in English.</h2>
<h2 class="heading-text-p"> A Free typing tutor in English to speed up your typing speed.
This is absolutely free and handy tool, you can use it without internet once it loaded. A Free English Typing tutorial give you
tips to increase your speed and accuracy. A large list of Chapters will able you to type more.<br>
<div class="row">
<div class="col-md-8"><h2> Increase your typing speed!</h2></div>


<div class="col-md-4 Slider animation rotateRight">
<div id="slider1" class="carousel slide" data-ride="carousel">
<!-- Indicators -->
<ol class="carousel-indicators">
<li data-target="#slider1" data-slide-to="0" class="active"></li>
<li data-target="#slider1" data-slide-to="1"></li>
<li data-target="#slider1" data-slide-to="2"></li>

<!-- Wrapper for slides -->
<div class="carousel-inner" role="listbox">
<div class="item active">
<img src="./img/keyboard.png" alt="Keyboard">
<div class="item">
<img src="./img/r1.png" alt="Result">
<div class="item">
<img src="./img/s1.png" alt="Share">
<section class="container-fluid main">
<div class="col-md-1">
<div class="row stages" id="stages">
<div class="col-md-4">
<h2> Choose Your Level </h2>
<button class="btn lg easy level" width="50px" value="easy">Easy</button>
<button class="btn lg normal level" value="normal">Normal</button>
<button class="btn lg hard level" value="hard">Hard</button>
<div class="col-md-2">
<div class="panel panel-primary">
<div class="panel-heading">
<h3 class="Tim">Timer</h3>
<input type="hidden" id="currentSpeed" value="">
<input type="hidden" id="cTime" value="0">
<input type="hidden" id="tDD" value="56">
<div class="panel-body text-center">
<label> Choose Time </label>
<select id="time" name ="time" class="form-control">
<option value="5" selected> 5 Seconds </option>
<option value="30" selected> 30 Seconds </option>
<option value="60" selected> 1 Minutes </option>
<option value="300"> 5 Minutes </option>
<option value="600"> 10 Minutes </option>
<div class="col-md-4">
<button class="btn lg btn-danger"> Time Ramining </button>
<div class="timer" id="timer">

<button class="btn lg btn-info" id="start_test"> Start Test </button>

<div class="Reset" id="reset">
<button class="btn lg btn-success" onclick="Reload_page()"> Reset </button>
<div class="row text-container clear" id="tt">
<div class="col-md-5">
<div class="panel panel-Color">
<div class="panel-heading left-align">
<div class="row">
<div class="col-sm-4"><h4 class="Chapter-Change">Select Chapter</h4><span id="Chapter_Number"></span> </div>
<div class="col-sm-8">
<input type="hidden" id="level" value="normal">
<select class="form-control" id="Chapter-Change" onchange="cChapter(this.value)">
<option value="1"> Chapter 1 </option>
<option value="2"> Chapter 2 </option>
<option value="3"> Chapter 3 </option>
<option value="4"> Chapter 4 </option>
<option value="5"> Chapter 5 </option>
<div class="panel-footer">
<input type="hidden" id="hd_dt" value="">
<div id="Box"></div>
<div class="col-md-5">
<div class="panel panel-Color">
<div class="panel-heading">
Start from Here <span id="show"> </span> | <span id="current_speed"></span>
<div class="panel-footer">
<div id="text-editor" contenteditable> </div>



<div class="col-md-12">
<div id="container">
<ul id="keyboard">
<li class="symbol" id ="À"><span class="off">`</span><span class="on">~</span></li>
<li class="symbol" id="1"><span class="off">1</span><span class="on">!</span></li>
<li class="symbol" id="2"><span class="off">2</span><span class="on">@</span></li>
<li class="symbol" id="3"><span class="off">3</span><span class="on">#</span></li>
<li class="symbol" id ="4"><span class="off">4</span><span class="on">$</span></li>
<li class="symbol" id="5"><span class="off">5</span><span class="on">%</span></li>
<li class="symbol" id="6"><span class="off">6</span><span class="on">^</span></li>
<li class="symbol" id="7"><span class="off">7</span><span class="on">&amp;</span></li>
<li class="symbol" id="8"><span class="off">8</span><span class="on">*</span></li>
<li class="symbol" id="9"><span class="off">9</span><span class="on">(</span></li>
<li class="symbol" id="0"><span class="off">0</span><span class="on">)</span></li>
<li class="symbol" id ="½"><span class="off">-</span><span class="on">_</span></li>
<li class="symbol" id="»"><span class="off">=</span><span class="on">+</span></li>
<li class="delete lastitem" id = "bckspace"> BackSpace</li>

<li class="tab"> Tab </li>
<li id="Q">Q</li>
<li id ="W" value = "ram">W</li>
<li id ="E">E</li>
<li id="R">R</li>
<li id="T">T</li>
<li id="Y">Y</li>
<li id = "U">U</li>
<li id="I">I</li>
<li id="O">O</li>
<li id="P">P</li>
<li class="symbol" id ="Û" ><span class="off">[</span><span class="on">{</span></li>
<li class="symbol" id="Ý"><span class="off">]</span><span class="on">}</span></li>
<li class="symbol lastitem" id ="Ü"><span class="off">\</span><span class="on">|</span></li>

<li class="capslock">caps lock</li>
<li id ="A">A</li>
<li id = "S">S</li>
<li id = "D">D</li>
<li id = "F">F</li>
<li id = "G">G</li>
<li id= "H">H</li>
<li id = "J">J</li>
<li id = "K">K</li>
<li id = "L">L</li>
<li class="symbol" id ="º"><span class="off">;</span><span class="on">:</span></li>
<li class="symbol" id='Þ'><span class="off">'</span><span class="on">&quot;</span></li>
<li class="return lastitem" >  Enter</li>

<li class="left-shift">▲ Shift</li>
<li id ="Z">Z</li>
<li class="letter" id="X">X</li>
<li class="letter" id="C">C</li>
<li id="V">V</li>
<li id="B">B</li>
<li id="N">N</li>
<li id="M">M</li>
<li class="symbol" id= "¼"><span class="off">,</span><span class="on">&lt;</span></li>
<li class="symbol" id="¾"><span class="off">.</span><span class="on">&gt;</span></li>
<li class="symbol" id="¿"><span class="off">/</span><span class="on">?</span></li>
<li class="right-shift lastitem">▲ Shift</li>
<li class="space lastitem" id = "space">&nbsp; Spacebar</li>


<!-- Footer -->

<div id="output"></div>
<script> !function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],p=/^http:/.test(d.location)?'http':'https';
fjs.parentNode.insertBefore(js,fjs);}}(document, 'script', 'twitter-wjs');</script>

<div id="fb-root"></div>
<script>(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); = id;
js.src = "//";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>

<script src="" async defer></script>
<!-- jQuery -->
<script src="" type="text/javascript"></script>
<script src="" type="text/javascript"></script>
<script src="js/lessions.js"></script>
<script src="js/app.js"></script>

<div class="modal fade" id="result_modal" tabindex="-1" role="dialog">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title">Result</h4>
<div class="modal-body">
<p>Your Accuracy is: <span id="accu"></span>%</p>
<p>Your Speed is: <span id="net_speed"></span> WPM.</p>
<p>Total Keystrock: <span id="tot_keystrock"></span>.</p>
<div class="modal-footer">
<div class="col-md-6">
<button type="button" onclick="tweetit();">Tweet</button></div>

<!-- Hidden Form -->
<form action="http://localhost/fyp/hello.php" method="get">
<input type="hidden" id="accuh" name="accuh"/>
<input type="hidden" id="net_speedh" name="net_speedh"/>
<input type="hidden" id="tot_keystrockh" name="tot_keystrockh"/>
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<button type="submit" onclick="valueCall()" id="submit" name="submit" class="btn btn-primary">Submit</button>
</div><!-- /.modal-content -->
</div><!-- /.modal-dialog -->
</div><!-- /.modal -->
.fb-share-button{padding:3px 6px;margin-top: -3px;}

<script type="text/javascript">
function Reload_page(){


<!-- Numbers Being Displayed -->


CSS Folder Files

css files for styling the typing tutor
Figure: CSS files for styling the typing tutor

Click Here to download the js file for typing tutor project code.CSS files for typing tutor project code

JS Files

Click Here to download the js file for typing tutor project code.

Prof.Fazal Rehman Shamil (Available for Professional Discussions)
1. Message on Facebook page for discussions,
2. Video lectures on Youtube
3. Email is only for Advertisement/business enquiries.