JavaScript Dice
data:image/s3,"s3://crabby-images/12f74/12f74368facf817452140ab741d9d3dd856ff8c0" alt="main.jpg"
This is a basic program that showcases how a javascript code works in collaboration to an html.
This can be used to teach kids about the basics of programming.
First Things First
data:image/s3,"s3://crabby-images/5c5a0/5c5a002a0f85355a66a554106dd897b95dfc26d1" alt="001.jpg"
data:image/s3,"s3://crabby-images/c5deb/c5debc3437357eea2a2851a909974a68f4b379b2" alt="002.jpg"
data:image/s3,"s3://crabby-images/4f3eb/4f3eb2a7f6ae826fb8d811ab092a708fc04d5148" alt="003.jpg"
First start with a basic notepad file.
Rename the file to make it html.
Open it with notepad. You can use better editors like notepad ++
Also keep the file open in a browser to see how is it behaving.
First Few Lines
data:image/s3,"s3://crabby-images/3fa0e/3fa0e137eafe7968533fa2fe331fcf6bdfa90d16" alt="005.jpg"
data:image/s3,"s3://crabby-images/6bd97/6bd976f18c266dd0a4b7eeae0c61f4956d23b68d" alt="006.jpg"
data:image/s3,"s3://crabby-images/e69f5/e69f52031eadad0158b96c368ac211c8f0e85a49" alt="007.jpg"
data:image/s3,"s3://crabby-images/b8cbd/b8cbdd73620f1a24e5ea9ca4f53232331cb06ea6" alt="004.jpg"
Make an html tag body tag and script tag one inside the other.
Make a table with 3 rows and 3 columns. Write something in it to make it visible.
Main Part
data:image/s3,"s3://crabby-images/9bbb5/9bbb522ffe579afbac00778d6b5243e410f53f4f" alt="008.jpg"
data:image/s3,"s3://crabby-images/6dc77/6dc77f5f55dcb2a865c69a9c84f9802c81889d16" alt="009.jpg"
Make divs to play as placeholders which will be used to place the dots for the dice.
Also make a button which calls a particular function which will contain the code for rolling the dice.
Error Handling
data:image/s3,"s3://crabby-images/874dc/874dc287477bf76ec2916bd72023ee24260b4b60" alt="010.jpg"
data:image/s3,"s3://crabby-images/7d7c2/7d7c2e6c9cfd441a05f80385fae8ce5f088c82f6" alt="011.jpg"
As you make the button, error will appear as you have not created the function.
Go ahead and make a blank function with the same name as given in the button inside the script tag.
Randomness
data:image/s3,"s3://crabby-images/8d2a7/8d2a7a911d44aafc8e92dea3a488acddc235dca8" alt="012.jpg"
Make a random number generator which will cycle between 1 to 6 so as to make the dice look real.
Clean Up Code
data:image/s3,"s3://crabby-images/9141e/9141ec16dc107975560955e27e83443c4dd41378" alt="013.jpg"
Fill the divs with blanks first so that the dice does not look scrambled.
Fill the Dice
data:image/s3,"s3://crabby-images/5cc23/5cc236a59849f88a15f3f2b33a12b7e82345e218" alt="diceform.jpg"
data:image/s3,"s3://crabby-images/e752a/e752a244d0e0c11eec919ad565f9f97225aec9d0" alt="014.jpg"
data:image/s3,"s3://crabby-images/9e801/9e80119de074fbf5feabc645325a03eedb55f6d9" alt="015.jpg"
As per the logic of the dots fill the function with conditions so as to properly fill the dots.
Also make an image that looks like a dot. Save it in the same folder as the code.
Finishing
data:image/s3,"s3://crabby-images/fe14c/fe14ca439b76301bc75bcfe72b09a1f1a864a11c" alt="016.jpg"
data:image/s3,"s3://crabby-images/15702/1570263f66b796ea629f35d757795867ac53fcc0" alt="017.jpg"
data:image/s3,"s3://crabby-images/23eda/23eda913d30821e4d5df7298c2eeaccc1c84e297" alt="018.jpg"
data:image/s3,"s3://crabby-images/a388f/a388f570376c9bb1eaa05a1aa7685e38c7e0c890" alt="019.jpg"
data:image/s3,"s3://crabby-images/bdf02/bdf02d2e048e621b9d72e520aa741c24a5e73536" alt="020.jpg"
data:image/s3,"s3://crabby-images/d5a21/d5a21036940ce1070ab5136744a6e49f3d4277be" alt="021.jpg"
Your code is almost ready now.
You can see that the table gets resized as you click the button.
You need to set the size of the rows and columns so that the table gets solidified and does not change shape.
You also need to make the dots at the middle of the table cells. Set the alignment for that.
Lastly what you can do is change the border to 0 to make the dice more realistic.
You are done. Enjoy your first javascript code. Full code is available in the next step.
Code
data:image/s3,"s3://crabby-images/9a550/9a5502be3308b8a60beb47fc48d2e5001d60cc2a" alt="dice.png"
<html> <body> <table border=0> <tr height=20> <td width=20 align=center><div id="cell11"></div></td> <td width=20 align=center><div id="cell12"></div></td> <td width=20 align=center><div id="cell13"></div></td> </tr> <tr height=20> <td width=20 align=center><div id="cell21"></div></td> <td width=20 align=center><div id="cell22"></div></td> <td width=20 align=center><div id="cell23"></div></td> </tr> <tr height=20> <td width=20 align=center><div id="cell31"></div></td> <td width=20 align=center><div id="cell32"></div></td> <td width=20 align=center><div id="cell33"></div></td> </tr> </table> <button onclick=calculate()>Roll</button> <script> function calculate(){ let x = Math.floor((Math.random() * 6) + 1); document.getElementById("cell11").innerHTML = ""; document.getElementById("cell12").innerHTML = ""; document.getElementById("cell13").innerHTML = ""; document.getElementById("cell21").innerHTML = ""; document.getElementById("cell22").innerHTML = ""; document.getElementById("cell23").innerHTML = ""; document.getElementById("cell31").innerHTML = ""; document.getElementById("cell32").innerHTML = ""; document.getElementById("cell33").innerHTML = ""; if (x==2 || x==3 || x==4 || x==5 || x==6){ document.getElementById("cell11").innerHTML = "<img src=dice.png>"; } if (x==4 || x==5 || x==6){ document.getElementById("cell13").innerHTML = "<img src=dice.png>"; } if (x==6){ document.getElementById("cell21").innerHTML = "<img src=dice.png>"; } if (x==1 || x==3 || x==5){ document.getElementById("cell22").innerHTML = "<img src=dice.png>"; } if (x==6){ document.getElementById("cell23").innerHTML = "<img src=dice.png>"; } if (x==4 || x==5 || x==6){ document.getElementById("cell31").innerHTML = "<img src=dice.png>"; } if (x==2 || x==3 || x==4 || x==5 || x==6){ document.getElementById("cell33").innerHTML = "<img src=dice.png>"; } } </script> </body> </html>