Create a Simple Tic Tac Toe Game with JavaScript, HTML & CSS for Beginners | 2022 Tutorial

  Рет қаралды 84,402

Coding With Siphiwo

Coding With Siphiwo

Күн бұрын

Пікірлер: 109
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey guys, do not forget that at the end of each video I leave a challenge to complete. Don't be shy to leave a link here for review of how you completed that challenge. You grow by doing 🧑‍💻👩‍💻
@OsamaMohamedKhalil
@OsamaMohamedKhalil 2 жыл бұрын
thank you for your effrot, you have some mistakes in code when X is won don't show via heading one also with o and solution is * in function box clicked() you can add that : if (currentPlayer == X_TEXT){ playerText.innerHTML = "X Player has won!"; }else{ playerText.innerHTML = "O Player has won!"; } *in function restart() you can also add that to return the header with normal status before playing: * playerText.innerHTML = "Tic Tie Toe"; and finally i enjoy with your videos
@souped-space
@souped-space 3 ай бұрын
Im 11 and learning html css and JavaScript and I just wanted to say thank you this is a really good way to start
@rae185
@rae185 Жыл бұрын
Helpful vid. My project isnt exactly tic tac toe but i think (yikes) some logic of this game is gonna help me in the process. i hope to get my game working. pray for me! haha
@Huzaifajunaid566
@Huzaifajunaid566 2 жыл бұрын
Thank you so much! I just got into javascript and your tutorial was absolutely amazing! Best begginer tutorial i've seen! You are a legend!
@theCuriousCivilEngineer
@theCuriousCivilEngineer Жыл бұрын
Great video. I was looking for such a video for a few day now. The videos I found was very complicated and the were not beginner friendly. This video is very nice especially the javascript part, the logic is very straight forward and well explained. thanks for the great video I have learned a lot from it. Keep up the good work 💯
@GetQuote
@GetQuote Жыл бұрын
Man am new on this channel, but I love this guy!
@maresolaris
@maresolaris 11 ай бұрын
In response to the assignment to stop being able to play after X or O has won, I declared a global variable (let aPlayerHasWon = false) and will do that also in the restart routine. In case of a winner, I set the value of aPlayerHasWon to true. In the beginning of the function boxClicked() I now put if(aPlayHasWon) return. This prevents the game to continue. When the restart button is pressed the game is "released" due to the value of aPlayerHasWon. I really enjoyed this tutorial, which is very helpful! A small issue: in the video you do not use the .innerHTML to set the playerText, however you do in the code provided (thanks!). I was a little hard to find at first ;-) (nice exercise though). You gained a fan.
@siphiwocode
@siphiwocode 11 ай бұрын
Thanks for completing the assignment. I believe that we learn best by doing so that is huge 👍 on your side. Appreciate your sub!
@michaelerossable
@michaelerossable 2 жыл бұрын
Great video thanks! Spent a bunch of time with it today. Lots of videos about how to make tic-tac-toe and yours spoke to me. I added ".innerText" to playerText in the boxClicked() and restart() functions, and did the challenges at the end with a bunch of trial and error, some googling, and your extra video. Subscribed and looking forward to doing more of your vids. Great stuff! 😁
@siphiwocode
@siphiwocode 2 жыл бұрын
Really glad you enjoyed it
@tamarasworld22
@tamarasworld22 4 ай бұрын
thank you. i tried it and it came out exact
@dwyt
@dwyt 11 ай бұрын
fantastic video great teacher. Thank you
@donnevanbiljon6337
@donnevanbiljon6337 Жыл бұрын
I am studying IT and had to leave my home country (South Africa 😢) I need help with an assignment while being homesick. The i came across your video and with 5 seconds into the video i knew were you were from. Not only did your video make my day but will definitely help my studies 😊
@siphiwocode
@siphiwocode Жыл бұрын
Supa glad I could help both emotionally and with your studies.
@hugostiglitz1254
@hugostiglitz1254 2 жыл бұрын
Excellent tutorial and it seems that you explain very well, I could not understand 100% because I still do not know English very well but it helped me a lot. Thanks.
@siphiwocode
@siphiwocode 2 жыл бұрын
I'm glad that you could at least following along with the video
@peaklegacy146
@peaklegacy146 2 жыл бұрын
800th Subscriber!!🥳 Most well explained video I've ever seen!
@siphiwocode
@siphiwocode 2 жыл бұрын
Wow, thanks! Never thought I would reach 800 subs let alone have some be excited to be number 800 😁
@zzzzzzzaxc
@zzzzzzzaxc Жыл бұрын
I don't understand this point. let start = () => {boxes.forEach(box => {box.addEventListener('click',boxClicked) });} 14:16 where does the box come from and what is it?
@siphiwocode
@siphiwocode Жыл бұрын
On line 3 you will that I declare a variable that contains an array of boxes. This are the boxes from the html. That is why when I loop over the array, I name the single entry "box"
@stopstalkingme2023
@stopstalkingme2023 2 жыл бұрын
A game with no draw feature. Nice
@siphiwocode
@siphiwocode 2 жыл бұрын
I encourage everyone to try and implement this functionality in this game on their own. This is part of developing your coding skills. If you just want the solution / draw functionality, here is the video kzbin.info/www/bejne/r2O8Y2iobpmEgtU
@stephmukami3817
@stephmukami3817 Жыл бұрын
great explanation and robust code,thanks
@muhammadyusufsodiqov3580
@muhammadyusufsodiqov3580 2 жыл бұрын
Wonderful bro. Thanks a lot
@siphiwocode
@siphiwocode 2 жыл бұрын
Always welcome
@bartlight6810
@bartlight6810 Жыл бұрын
Very helpful video, thank you!
@siphiwocode
@siphiwocode Жыл бұрын
Glad it was helpful! All the best with your dev journey
@openworld7585
@openworld7585 2 жыл бұрын
Thank you so much for great explanations
@siphiwocode
@siphiwocode 2 жыл бұрын
I'm really glad you enjoyed it ☺. It there a link where I can see your solution to the challenge?
@blueberry5992
@blueberry5992 Жыл бұрын
keep up the great work ❤
@siphiwocode
@siphiwocode Жыл бұрын
Thank you! Will do!
@blueberry5992
@blueberry5992 Жыл бұрын
@@siphiwocode but ur codesource does not work why?
@fayozbekotajonov5270
@fayozbekotajonov5270 2 жыл бұрын
good job
@siphiwocode
@siphiwocode 2 жыл бұрын
Glad you like the video 👌
@jeffa2006
@jeffa2006 Жыл бұрын
3:48 its not working for me the styling
@siphiwocode
@siphiwocode Жыл бұрын
Make sure your style.css file is in the same directory as your index.html file. This could be the reason why your css file is not picking up. Hope this helps.
@farintinobialor7023
@farintinobialor7023 Жыл бұрын
Thank you man.👍
@siphiwocode
@siphiwocode Жыл бұрын
You bet
@ellzz2431
@ellzz2431 2 жыл бұрын
Hi there I’ve completed it but the player won trigger is not coming up after they have won and also when the players have draws it doesn’t come up either but the colour for when they win and draw works. It’s the innerHTML part that doesn’t work for some reason. So it works without the innerHTML but with it the player won and the draw part doesn’t change
@siphiwocode
@siphiwocode 2 жыл бұрын
Glad you tried to do the challenge and complete the game. For your issue, I suggest watching the solution here: kzbin.info/www/bejne/r2O8Y2iobpmEgtU
@krantiwaghmare2710
@krantiwaghmare2710 Жыл бұрын
thank you
@siphiwocode
@siphiwocode 11 ай бұрын
You're welcome
@MrBrady95
@MrBrady95 Жыл бұрын
Liked and subscribed! Thanks
@siphiwocode
@siphiwocode Жыл бұрын
Awesome, thank you!
@ojichan982
@ojichan982 Жыл бұрын
hi there , what modifications can be done so instead of maping the winning blocks i want a line to be drawn ?
@siphiwocode
@siphiwocode Жыл бұрын
Currently the blocks highlight function uses the css to highlight the winning combo. The issue or challenge with using lines is that the winning combo wont always be in a straight line. You will need to check the position of the second block from the first one in order to draw the line vertical, horizontal or diagonal. Drop me a link once you get this right 😉
@bibekdas6277
@bibekdas6277 Жыл бұрын
can you tell me what theme is that..?
@siphiwocode
@siphiwocode Жыл бұрын
Hey man, this theme is called Night Owl.
@galekwansango5321
@galekwansango5321 2 жыл бұрын
Can you include a link for files in the description? It would be great if we can view and access the code...
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey Galekwan, I have added a github repo link in the description of the video. Thanks for the watch, like, comment and sub 👌
@ixnbtw6274
@ixnbtw6274 2 жыл бұрын
I copied the code from github but the x/o dont get placed then I click on the field. Do you know how to fix that
@siphiwocode
@siphiwocode 2 жыл бұрын
In the vide you will notice that I use VSCode and run the Live Server extension. This allows me to run the file with no issue. So I take it you have downloaded the file, and double clicked on the index.html file. You need to set the script path by changing it from to . The DOT makes the difference 👌
@ixnbtw6274
@ixnbtw6274 2 жыл бұрын
@@siphiwocode thank you very much it works now!
@gearsdan
@gearsdan 2 жыл бұрын
hi siphiwo! watched your video because i just started learning Javascript. would you be able to convert the arro function to a regular function for me? i havent learned arror function yet and lines 10 and 11 are different for me. same for line 21 as well
@siphiwocode
@siphiwocode 2 жыл бұрын
Hi Dan. You can covert any arrow function changing a couple of things. 1. Instead of: const updateUI = () => {} a normal function would be: function updateUI() {}. You an apply this to all arrow functions. Hope this helps
@ixnbtw6274
@ixnbtw6274 2 жыл бұрын
@@siphiwocode hey siphiwo, I have issues with converting the arrow function boxes.forEach(box => { box.innerText = '' box.style.backgroundColor = '' }) or function startGame() { boxes.forEach(box => box.addEventListener('click', boxClicked)) } to a normal function, could you help me out?
@RushikaPanchal
@RushikaPanchal Жыл бұрын
I having the problem with css my box lines are in vertical formate how can I fix it?
@siphiwocode
@siphiwocode Жыл бұрын
Hi Rushika, unfortunately it is a bit difficult to assist you with your issue as it is unclear to me. You can make sure that you follow both the creation and solution to the Tic Tac Toe game videos. Hope you come right and good luck on your coding journey
@RushikaPanchal
@RushikaPanchal Жыл бұрын
@@siphiwocode OK thanks for replying
@blackzeke4428
@blackzeke4428 Жыл бұрын
Please can you make a video about playing with human vs computer how do you make it possible to play with vs the computer
@siphiwocode
@siphiwocode Жыл бұрын
This is really interesting. I will add it to my list of videos. Thanks for the idea 👍
@Qzey-x8s
@Qzey-x8s Жыл бұрын
How did you open the part in minutes 3.44?
@siphiwocode
@siphiwocode Жыл бұрын
I assume you are referring to the code-editor sidebar right. I used Ctrl+B to toggle that. Hide and show the files.
@adsye0015
@adsye0015 Жыл бұрын
hey i can't play multiplayer that only one x show why can help me
@siphiwocode
@siphiwocode Жыл бұрын
This can be caused by a number of things, my suggestion would be first check the variables where you set the X and O if they set correct. From there just follow both videos to make sure you not skipping a step. Happy coding 👍
@anjalimishra2428
@anjalimishra2428 Жыл бұрын
how to get the google font
@siphiwocode
@siphiwocode Жыл бұрын
You can go to fonts.google.com. Hope this helps
@esmeraldagonzalez9336
@esmeraldagonzalez9336 Жыл бұрын
Hey so I loved the video for me this is my very first project that im working on and it was really easy to follow through and understand what is going on however I am confused when you use document in your js files because it says document is undefined. Is there something that I may be missing?
@siphiwocode
@siphiwocode Жыл бұрын
Glad it was helpful! Can you point me the minute you are referring to. This will help me to better assist you
@hazem342
@hazem342 6 ай бұрын
is it python?
@sarozz860
@sarozz860 Жыл бұрын
why sign is not clicking on these project . i had downloaded it form github
@siphiwocode
@siphiwocode Жыл бұрын
Hi, did you follow the video tutorial in order to complete the project? Check-out the follow-up video where I explain how to add more features to the application. Hope that helps
@shashank7533
@shashank7533 Жыл бұрын
A silly question from a beginner whats the difference between writing the script in head and body as i wrote the script in head it didnt work and why is it that stylesheet works in the head but not the js file .... can someone explain plzzz???
@siphiwocode
@siphiwocode Жыл бұрын
So code gets read from top to bottom right. No imagine in your script you are looking for a div-tag that has not rendered yet, that script will be null or undefined which will cause your code not work correctly. Stylesheet on the other hand are not manipulators meaning they don't change the the DOM but rather adds to it. if that makes sense.
@SHERSHAAH555
@SHERSHAAH555 2 жыл бұрын
what about the draw condition
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey, I highly recommend trying to figure it out on your own first as this will help with your learning process. But you can find the solution here: kzbin.info/www/bejne/r2O8Y2iobpmEgtU
@SHERSHAAH555
@SHERSHAAH555 2 жыл бұрын
@@siphiwocode yeah after watching this i think for a while and i got the solution thanks for sharing your knowledge on the base program
@kamalancs9746
@kamalancs9746 9 ай бұрын
At the end you forgot to display the player won msg in h1 tag.
@siphiwocode
@siphiwocode 9 ай бұрын
Oh snap, thanks for watching till the end man. I trust you added it in your project right
@isabelrobles8019
@isabelrobles8019 2 жыл бұрын
I'm confused a bit because idk how Google fonts was used in this
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey Isabel , I pasted the google font which I got from fonts.google.com/ Once you have selected the font, you got the option to download it or include it using the link tag shown here at 03:40
@heavyrain5388
@heavyrain5388 Жыл бұрын
Hi, can you do a version where it's player vs computer? A very stupid computer that just randomly places its symbol on available cells without analyzing the player's choices. 🙏
@siphiwocode
@siphiwocode Жыл бұрын
That sound like a great idea but it will need to know the blocks already selected so that the pc choose available blocks. Will definitely add this to my todo list. Thanks 😉
@heavyrain5388
@heavyrain5388 Жыл бұрын
@@siphiwocode hi it's just a suggestion tho, please don't feel like I'm pressuring you ya. 😅😅
@jinksofficial476
@jinksofficial476 Жыл бұрын
I copied everything and it doesn't work. Help please!!
@siphiwocode
@siphiwocode Жыл бұрын
You can download the file from my github account and compare the code. Most of the time is just a simple naming conversion that is not the same which could break the entire code base. Hope this helps
@redewanmahmud2917
@redewanmahmud2917 Жыл бұрын
What if no one wins? Can't there be a drawn match? 😅
@siphiwocode
@siphiwocode Жыл бұрын
There can be yes. Share the code once you have expanded on this one. That is the progress of learning...
@thesportsbubble6705
@thesportsbubble6705 2 жыл бұрын
Did anyone else figure out how to add a draw function to the game?
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey man, took while but here is the solution to the end of this video. Hope you enjoy. kzbin.info/www/bejne/r2O8Y2iobpmEgtU
@thesportsbubble6705
@thesportsbubble6705 2 жыл бұрын
@@siphiwocode thank you!
@buddhalama4041
@buddhalama4041 2 жыл бұрын
I didn't understand the winning conditions 😢
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey Creep 😂 (that sounded funny in my head). I will be added a short video soon explaining the winning logic for you. Watch out for that soon 👍
@buddhalama4041
@buddhalama4041 2 жыл бұрын
@@siphiwocode okay will be waiting thanks😂
@arupde6320
@arupde6320 2 жыл бұрын
be regular
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey Arup, not really sure what you mean with "be regular" 🤔
@arupde6320
@arupde6320 2 жыл бұрын
@@siphiwocode upload on daily basis
@siphiwocode
@siphiwocode 2 жыл бұрын
@Arup missed your response there sorry, thank man. I will try to keep uploading weekly. Daily is abit out of the question for me at this point :)
@fayozbekotajonov5270
@fayozbekotajonov5270 2 жыл бұрын
:)
@siphiwocode
@siphiwocode 2 жыл бұрын
I can always count on you to watch the videos. Thanks for the support man 👍
@phlemuelnx
@phlemuelnx 2 жыл бұрын
Where is the source code?
@siphiwocode
@siphiwocode 2 жыл бұрын
Hey Lemuel, I have added a link to the github repo on the video description. Thanks for the watch, like, comment and sub 👌
@phlemuelnx
@phlemuelnx 2 жыл бұрын
@@siphiwocode Thank you so much!
@trainmonharrison7454
@trainmonharrison7454 Жыл бұрын
wanted to say great video but I am getting stuck on the part where you put const id = e.traget. id the issue I get is my event listener it is saying uncaught type error cannot read properties of the undefined id
@Abubakr-md6kz
@Abubakr-md6kz Жыл бұрын
This code defines an arrow function called start that adds a click event listener to each element in a collection of boxes. The forEach() method iterates over each element in the boxes collection and attaches a click event listener to each element. The event listener is a function called boxClicked, which is not defined in the code you provided. When a box is clicked, the boxClicked function will be called. The purpose of this function depends on its implementation, which is not shown in the code you provided.
@trainmonharrison7454
@trainmonharrison7454 Жыл бұрын
@@Abubakr-md6kz thx so much
@siphiwocode
@siphiwocode Жыл бұрын
Thanks Abudakr for jumping in and helping :)
@trainmonharrison7454
@trainmonharrison7454 Жыл бұрын
np thx for getting back to me I appreciate the help@@siphiwocode
A game of TicTacToe written in JavaScript ⭕
18:57
Bro Code
Рет қаралды 129 М.
Create a simple tic tac toe game using HTML, CSS, JavaScript
10:54
JavaScript Academy
Рет қаралды 189 М.
小丑教训坏蛋 #小丑 #天使 #shorts
00:49
好人小丑
Рет қаралды 54 МЛН
BAYGUYSTAN | 1 СЕРИЯ | bayGUYS
36:55
bayGUYS
Рет қаралды 1,9 МЛН
Cat mode and a glass of water #family #humor #fun
00:22
Kotiki_Z
Рет қаралды 42 МЛН
Subtle, yet Beautiful Scroll Animations
5:04
Beyond Fireship
Рет қаралды 1,8 МЛН
Learn Flexbox CSS in 8 minutes
8:16
Slaying The Dragon
Рет қаралды 1,7 МЛН
Build A Calculator With JavaScript Tutorial
38:50
Web Dev Simplified
Рет қаралды 1,5 МЛН
Code Tic Tac Toe Game in JavaScript HTML CSS
20:17
Kenny Yip Coding
Рет қаралды 32 М.
TIC TAC TOE Game || HTML CSS JS
10:47
Devang Vangane
Рет қаралды 591
How to code snake game in JavaScript
29:45
Kenny Yip Coding
Рет қаралды 120 М.
Parallax Scrolling Website | How to Make Website using Html CSS & Javascript
19:55
Build Tic Tac Toe With JavaScript - Tutorial
41:46
Web Dev Simplified
Рет қаралды 362 М.