- دوره آموزش JavaScript قسمت اول: چرا باید جاوا اسکریپت را یاد بگیریم؟
- دوره آموزش JavaScript قسمت دوم: شروع برنامه نویسی با javascript
- دوره آموزش JavaScript قسمت سوم: عملیات ریاضی و دستورات شرطی
- دوره آموزش JavaScript قسمت چهارم: توابع جاوا اسکریپت
- دوره آموزش JavaScript قسمت پنجم: آرایه ها و آبجکت ها
- دوره آموزش JavaScript قسمت ششم: حلقه ها
- دوره آموزش JavaScript قسمت هفتم: کار با رشته ها
- دوره آموزش JavaScript قسمت هشتم: شی گرایی در جاوا اسکریپت
- دوره آموزش JavaScript قسمت نهم: DOM
- دوره آموزش JavaScript قسمت دهم: رویدادهای جاوا اسکریپت
- دوره آموزش JavaScript قسمت یازدهم: توابع ریاضی و زمان
- دوره آموزش JavaScript قسمت دوازدهم: BOM
- دوره آموزش JavaScript قسمت سیزدهم: cookie و session
BOM قابلیتهایی است که مرورگر در اختیار برنامه نویسان میگذارد و خلاصه عبارت Browser Object Model میباشد. در این پست به بررسی این موضوع میپردازیم.
شی window بالاترین مرتبه اشیاء در جاوا اسکریپت است که حتی document نیز جزئی از آن محسوب میشود. شی window شامل عناصری است که میتوان روی BOMها عملیات انجام داد.
برای مشاهده کل اجزای window در کنسول عبارت window را تایپ کرده و انتر بزنید.
یکی از امکانات BOM مدیریت زمان است. میتوان با متد setTimeout دستور خاصی را پس از سپری شدن زمانی معین اجرا کرد. مثال زیر را ببینید:
function message(){
alert("run after 5 Seconds!");
}
setTimeout(message, 5000);
متد setTimeout دو ورودی میگیرد، اولی دستورات و دومی مقدار زمان به میلی ثانیه. بنابراین پس از 5 ثانیه از لود شدن صفحه پنجره PopUp نمایش داده میشود.
البته مثال فوق را به شکل زیر نیز میتوان باز نویسی کرد که تفاوتی در نتیجه ندارد:
setTimeout(function(){
alert("run after 5 Seconds!");
}, 5000);
توجه کنید که در بالا تابع نیازی به نام ندارد.
متد setInterval
این متد ورودیهایی مشابه متد setTimeout دارد با این تفاوت که عملیات مورد نظر را مکررا تا بی نهایت انجام میدهد. مثال زیر را ببینید:
setInterval(function(){
console.log("Hi from Hitos.ir");
}, 1000);
دستور فوق هر یک ثانیه دستور Hi from Hitos.ir را نمایش میدهد.
البته میتوان این متد را با شرایطی متوقف کرد. مثلا:
<html>
<head></head>
<body>
<button>STOP interval</button>
<script>
var interval;
interval = setInterval(function(){
console.log("Hi from Hitos.ir");
}, 1000);
var btn = document.getElementsByTagName('button');
btn[0].onclick= function(){
clearInterval(interval);
};
</script>
</body>
</html>
در سطر 6 یک متغیر با نام interval ایجاد نمودیم.
در سطر 7 متد setInterval را درون متغیر تعریف شده در سطر قبل قرار دادیم. با اجرا شدن متد setInterval هر یک ثانیه یکبار متن مشخص شده در console نمایش داده میشود.
در سطر 11 یک متغیر از کلید button ایجاد کردیم.
در سطر 12 بدلیل آرایه بودن متغیر عنصر صفرم آن را برای رویداد onclick آماده میکنیم. درون متد با clearInterval متد setInterval را با ذکر نام متغیر مخصوص به خود متوقف میکنیم.
location در javascript
location نیز زیر مجموعه شیء سراسری window میباشد. location را در console وارد کرده و اجزاء آن را مشاهده کنید.
می توانیم با متد href صفحه جاری را به آدرس جدیدی انتقال داد:
location.href= "http://hitor.ir";
البته میتوان مثلا تنها پورت را عوض کرد که این کار با دستور زیر امکان پذیر است:
location.port= "808";
شیء screen
این شی خصوصیاتی از صفحه نمایش دستگاه کاربر به شما میدهد. این دستور را در ابزار کنسول وارد کنید و خروجی را مشاهده کنید.
متد open
این متد برای باز کردن یک آدرس در تب جدید استفاده میشود. مثال زیر سایت هیتوس را در یک تب جدید برای شما باز میکند:
open('https://hitos.ir');
حالت پیچیده تر این متد به شکل زیر است:
open('https://hitos.ir', '', 'height=100,width=100').moveTo(900,900);
در بالا متد open سه ورودی دارد که ورودی اول همان آدرس، ورودی دوم را خالی میگذاریم و در ورودی سوم طول و عرض را برای پنجره جدید میدهیم.
با moveTo نقطهای که قصد داریم پنجره جدید در آن جا باز شود را مشخص میکنیم.
موقعیت مکانی کاربر
برای دریافت موقعیت مکانی کاربر از امکانات BOM مرورگر میتوان استفاده کرد. اگر قصد دریافت اطلاعات موقعیت مکانی کاربر را دارید یک پنجره PopUp به کاربر نشان داده میشود که از او برای دریافت اطلاعات اجازه کسب میشود. اگر کاربر این اجازه را ندهد شما نمیتوانید اطلاعات جغرافیایی او را مشاهده کنید.
مثال زیر را ببینید:
navigator.geolocation.getCurrentPosition(function(position){
console.log("latitude: " + position.coords.latitude + " longitude: " + position.coords.longitude);
}, function(){
console.log("blocked!");
})
در سطر اول و به ترتیب از اشیاء navigator.geolocation.getCurrentPosition
استفاده نموده که ورودی آن دو تابع است.
تابع اول موقعیت مکانی را میدهد و تابع دوم عکس العمل شما در صورت block کردن کاربر را شامل میشود.
تابع اول یک ورودی به نام position دارد که با متدهای coords.latitude و coords.longitude طول و عرض جغرافیایی را به ما میدهند.
تابع دوم هم به سادگی عبارت blocked را در کنسول نمایش میدهد.