ساخت یک بازی ساده با جاوا اسکریپت — از صفر تا صد

خرید بک لینک

در این مقاله با روش ساخت یک بازی ساده با جاوا اسکریپت آشنا میشویم. تنها راه یادگیری، تمرین است و در این راهنما قصد داریم با بررسی عملی روش دستکاری DOM شروع به بهبود مهارتهای خود بکنیم. با این که این مقاله برای افراد تازهکار نوشته شده است، اما به آن معنی نیست که اصلاً به درد توسعهدهندگان باتجربهتر نمیخورد. در این مقاله با موارد زیر آشنا خواهیم شد:

  • مبانی CSS و جاوا اسکریپت
  • مبانی Flexbox ،CSS3 و مدل لیآوت وب
  • دستکاری دینامیک DOM با استفاده از جاوا اسکریپت

طراحی بازی

ساخت یک بازی ساده با جاوا اسکریپت

بازی سادهای که میخواهیم طراحی کنیم، دارای شرایط زیر است:

  • در این بازی از یک تصویر به عنوان پسزمینه استفاده میشود و یک تصویر اردک در آن وجود دارد که قابل کلیک است.
  • زمانی که کاربر روی تصویر اردک کلیک کند، دو اتفاق میافتد:
    • امتیاز کنونی یک واحد افزایش مییابد.
    • اردک به یک موقعیت تصادفی جدید جابجا میشود.
  • این بازی با استفاده از قابلیتهای استاندارد ES6 ساخته میشود.
  • برای لیآوت از Flexbox استفاده شده است.

به عنوان یک قاعده کلی، نخستین کاری که در چنین مواردی باید انجام دهیم، تفکر در مورد رویکردی است که باید انتخاب کنیم. این بدان معنی است که باید هر گام را تحلیل کنیم و جزییاتی که باید برای به دست آوردن آن الزام خاص پیادهسازی شوند را مشخص ساخته باشیم. در ادامه این کار را انجام میدهیم.

برای حل این چالش به ترتیب گامهای زیر را باید برداریم. در این راه حل از رویکرد «تقسیم و حل» استفاده شده است.

  1. لیآوت را با استفاده از فایلها (تصویر پسزمینه و اردک) و یک کادر امتیاز پیادهسازی میکنیم.
  2. زمانی که روی تصویر اردک کلیک میشود، باید یک «شنونده رویداد» (event listener) وجود داشته باشد که تحریک شود.
  3. تابعی ایجاد میکنیم که امتیاز کنونی را افزایش دهد.
  4. تابعی میسازیم که اردک را به صورت تصادفی جابجا کند.

حال که مراحل اجرایی را شناختیم، بدون هرگونه توضیح اضافی به سراغ پیادهسازی عملی بازی میرویم.

لیآوت

لیآوت ما (فایل index.html) یک div به عنوان یک کانتینر دارد که دو تصویر پسزمینه و اردک در آن قرار میگیرند. در نهایت یک عنصر scoreContainer وجود دارد که متن score و همچنین مقدار امتیاز (به عنوان شمارنده) در آن جای میگیرد:

<div class="container">
     <img src="https://bit.ly/2Q4q14a" />
     <img id="duck" src="https://bit.ly/2KQJVKc" alt="duck" />
     <div class="scoreContainer">
       <div id="score-text">Score</div>
       <div id="score-counter">0</div>
    </div>
</div>

استایل این لیآوت نیز به صورت زیر است:

/*Make any img element responsive*/
img {
 max-width: 100%;
}
/*Set a fixed size for width and height and in an absolute position*/
#duck {
 margin: 50px;
 width: 100px;
 height: 100px;
 position: absolute;
 left: 100px;
 top: 100px;
}
/*Style for the Score container*/
.scoreContainer {
 background-color: black;
 width: 15%;
 height: 15%;
 color: #ffffff;
 top: 5%;
 right: 5%;
 border: 2px solid greenyellow;
 border-radius: 10px;
 display: flex;
 position: fixed;
 flex-direction: column;
 align-items: center;
}
#score-text {
 font-size: 1.5em;
}
#score-counter {
 font-size: 3.1em;
 font-weight: bold;
 color: #06e515;
}

جاوا اسکریپت

در این بخش اسکریپتهای لازم را توضیح میدهیم.

ایجاد شنونده رویداد

اکنون باید یک شنونده رویداد روی تصویر اردک ایجاد کنیم. زمانی که کاربر روی تصویر اردک کلیک میکند یک تابع اجرا خواهد شد:

//Get the target element
const duck = document.querySelector("#duck");
//Add the click event listener
duck.addEventListener("click", () => {
  //Dont forget call the functions here 
  increaseScore();
  moveDuck();
});

ایجاد تابع افزایش امتیاز کنونی

اینک که شنونده رویداد را ایجاد کردیم، باید یک تابع بسازیم که شمارنده را یک واحد افزایش دهد:

//Increase score by 1
const increaseScore = () => {
  //Get the content of the target element. The current value for score
  const score = document.querySelector("#score-counter").innerHTML;
  //Get the element to increase the value
  const scoreHTML = document.querySelector("#score-counter");
  //Cast the score value to Number type
  let count = Number(score);
  //Set the new score to the target element
  scoreHTML.innerHTML = count + 1;
};

ایجاد تابع جابجایی تصادفی اردک

اینک زمان آن رسیده است که اردک را جابجا کنیم. از آنجا که این حرکت اردک تصادفی است، بهتر است یک تابع کمکی بسازیم که یک عدد تصادفی میگیرد و سپس به یک موقعیت تصادفی انتساب میدهد. این تابع به صورت زیر است:

//Get a random number
const getRandomNum = (num) => {
  retu Math.floor(Math.random() * Math.floor(num));
}

در این مرحله باید یک تابع برای جابجا کردن اردک بسازیم. به این منظور از مشخصه innerWidth برای گرفتن عرض داخلی پنجره به صورت پیکسل و از مشخصه innerHeight برای دریافت ارتفاع داخلی پنجره به پیکسل استفاده میکنیم. ضمناً از تابع getRandomNum برای تنظیم مقادیر پیکسلی مشخصههای سمت بالا و چپ برای تعیین موقعیت عمودی و افقی اردک بهره میگیریم.

/*
Move the duck randomly 
*/
const moveDuck = () => {
  const w = window.innerWidth;
  const h = window.innerHeight;
  duck.style.top = getRandomNum(w) + "px";
  duck.style.left = getRandomNum(h) + "px";
};

سخن پایانی

به این ترتیب موفق شدیم بازی ساده خود را در جاوا اسکریپت طراحی کنیم. امیدواریم این راهنمای ساده توانسته باشد درک خوبی از روش دستکاری DOM در اختیار شما قرار دهد. کد کامل این بازی و همچنین یک نسخه اجرایی آن را میتوانید در این صفحه (+) ملاحظه کنید.

اگر این مطلب برای شما مفید بوده است، آموزشهای زیر نیز به شما پیشنهاد میشوند:

==

telegram
twitter

میثم لطفی

«میثم لطفی» دانشآموخته ریاضیات و شیفته فناوری به خصوص در حوزه رایانه است. وی در حال حاضر علاوه بر پیگیری همه علاقهمندیهای خود در رشتههای برنامهنویسی، کپیرایتینگ و تولید محتوای چندرسانهای، در زمینه نگارش مقالاتی با محوریت نرمافزار نیز با مجله فرادرس همکاری دارد.

نوشته ساخت یک بازی ساده با جاوا اسکریپت — از صفر تا صد اولین بار در مجله فرادرس. پدیدار شد.

مطالب درسی...

ما را در سایت مطالب درسی دنبال می‌کنید

برچسب: نویسنده: خنجی بازدید: 678 تاريخ: يکشنبه 18 اسفند 1398 ساعت: 12:18

صفحه بندی