কনসোল ইউটিলিটি API রেফারেন্স

সোফিয়া ইমেলিয়ানোভা
Sofia Emelianova

কনসোল ইউটিলিটিস এপিআই সাধারণ কাজগুলি সম্পাদনের জন্য সুবিধার ফাংশনগুলির একটি সংগ্রহ ধারণ করে: DOM উপাদানগুলি নির্বাচন এবং পরিদর্শন করা, বস্তুর অনুসন্ধান করা, পাঠযোগ্য বিন্যাসে ডেটা প্রদর্শন করা, প্রোফাইলার বন্ধ করা এবং শুরু করা, DOM ইভেন্ট এবং ফাংশন কলগুলি পর্যবেক্ষণ করা এবং আরও অনেক কিছু।

console.log() , console.error() , এবং বাকি console.* ফাংশন খুঁজছেন? কনসোল API রেফারেন্স দেখুন।

$_

$_ সাম্প্রতিক মূল্যায়ন করা এক্সপ্রেশনের মান প্রদান করে।

নিম্নলিখিত উদাহরণে, একটি সাধারণ অভিব্যক্তি ( 2 + 2 ) মূল্যায়ন করা হয়। $_ সম্পত্তিটি তারপর মূল্যায়ন করা হয়, যার মধ্যে একই মান রয়েছে:

$_ হল সবচেয়ে সাম্প্রতিক মূল্যায়ন করা অভিব্যক্তি।

পরবর্তী উদাহরণে, মূল্যায়ন করা অভিব্যক্তিতে প্রাথমিকভাবে নামের একটি অ্যারে রয়েছে। অ্যারের দৈর্ঘ্য খুঁজে পেতে $_.length মূল্যায়ন করলে, $_ তে সংরক্ষিত মান সর্বশেষ মূল্যায়নকৃত অভিব্যক্তিতে পরিবর্তিত হয়, 4:

$_ পরিবর্তন হয় যখন নতুন কমান্ড মূল্যায়ন করা হয়।

$0 - $4

$0 , $1 , $2 , $3 এবং $4 কমান্ডগুলি এলিমেন্টস প্যানেলের মধ্যে পরিদর্শন করা শেষ পাঁচটি DOM উপাদান বা প্রোফাইল প্যানেলে নির্বাচিত শেষ পাঁচটি জাভাস্ক্রিপ্ট হিপ অবজেক্টের ঐতিহাসিক রেফারেন্স হিসাবে কাজ করে৷ $0 সবচেয়ে সাম্প্রতিক নির্বাচিত উপাদান বা জাভাস্ক্রিপ্ট অবজেক্ট প্রদান করে, $1 সাম্প্রতিক নির্বাচিত দ্বিতীয়টি প্রদান করে এবং আরও অনেক কিছু।

নিম্নলিখিত উদাহরণে, উপাদান প্যানেলে একটি img উপাদান নির্বাচন করা হয়েছে। কনসোল ড্রয়ারে, $0 মূল্যায়ন করা হয়েছে এবং একই উপাদান প্রদর্শন করে:

$0 এর উদাহরণ।

নীচের ছবিটি একই পৃষ্ঠায় নির্বাচিত একটি ভিন্ন উপাদান দেখায়। $0 এখন নতুন নির্বাচিত উপাদানকে বোঝায়, যখন $1 পূর্বে নির্বাচিত একটি প্রদান করে:

$1 এর উদাহরণ।

$(নির্বাচক [, startNode])

$(selector) নির্দিষ্ট CSS নির্বাচকের সাথে প্রথম DOM উপাদানের রেফারেন্স প্রদান করে। একটি আর্গুমেন্টের সাথে কল করা হলে, এই ফাংশনটি document.querySelector() ফাংশনের জন্য একটি শর্টকাট।

নিম্নলিখিত উদাহরণটি নথিতে প্রথম <img> উপাদানের একটি রেফারেন্স প্রদান করে:

$('img') এর উদাহরণ।

প্রত্যাবর্তিত ফলাফলে ডান-ক্লিক করুন এবং DOM-এ এটি খুঁজে পেতে উপাদান প্যানেলে প্রকাশ নির্বাচন করুন, অথবা পৃষ্ঠায় এটি দেখানোর জন্য ভিউতে স্ক্রোল করুন

নিম্নলিখিত উদাহরণটি বর্তমানে নির্বাচিত উপাদানটির একটি রেফারেন্স প্রদান করে এবং এর src সম্পত্তি প্রদর্শন করে:

$('img').src এর উদাহরণ।

এই ফাংশনটি একটি দ্বিতীয় প্যারামিটার, startNode সমর্থন করে, যা একটি 'উপাদান' বা নোড নির্দিষ্ট করে যেখান থেকে উপাদানগুলি অনুসন্ধান করতে হবে। এই প্যারামিটারের ডিফল্ট মান হল document

নিম্নলিখিত উদাহরণটি প্রথম img উপাদানের একটি রেফারেন্স প্রদান করে যা devsite-header-background এর বংশধর, এবং এর src বৈশিষ্ট্য প্রদর্শন করে:

$('img', div).src এর উদাহরণ।

$$(selector [, startNode])

$$(নির্বাচক) প্রদত্ত CSS নির্বাচকের সাথে মেলে এমন উপাদানগুলির একটি অ্যারে প্রদান করে। এই কমান্ডটি Array.from( document.querySelectorAll() ) কল করার সমতুল্য।

নিম্নলিখিত উদাহরণ ব্যবহার করে $$() to create an array of all <img> elements in the current document and displays the value of each element's src property:

let images = $$('img'); for (let each of images) { console.log(each.src); }

<!-- notranslate l10n-placeholder: l10n-placeholder3 -->()</code> ব্যবহার করার উদাহরণ সমস্ত <code translate= একটি অ্যারে তৈরি করতে <img> উপাদান যা বর্তমান নথিতে নির্বাচিত নোডের পরে প্রদর্শিত হয়:

let images = $$('img', document.querySelector('.devsite-header-background'));
for (let each of images) {
  console.log(each.src);
}

নথিতে নির্বাচিত ডিভ উপাদানের পরে প্রদর্শিত সমস্ত চিত্র নির্বাচন করতে এবং তাদের উত্সগুলি প্রদর্শন করতে $() ব্যবহার করার উদাহরণ।

$x(পথ [, startNode])

$x(path) DOM উপাদানগুলির একটি অ্যারে প্রদান করে যা প্রদত্ত XPath এক্সপ্রেশনের সাথে মেলে।

উদাহরণস্বরূপ, নিম্নলিখিতগুলি পৃষ্ঠার সমস্ত <p> উপাদানগুলি প্রদান করে:

$x("//p")

একটি XPath নির্বাচক ব্যবহার করার উদাহরণ।

নিম্নলিখিত উদাহরণটি সমস্ত <p> উপাদানগুলি প্রদান করে যেগুলিতে <a> উপাদান রয়েছে:

$x("//p[a]")

আরও জটিল XPath নির্বাচক ব্যবহার করার উদাহরণ।

অন্যান্য নির্বাচক ফাংশনের অনুরূপ, $x(path) এর একটি ঐচ্ছিক দ্বিতীয় প্যারামিটার রয়েছে, startNode , যা একটি উপাদান বা নোড নির্দিষ্ট করে যেখান থেকে উপাদানগুলি অনুসন্ধান করতে হবে।

startNode সহ একটি XPath নির্বাচক ব্যবহার করার উদাহরণ।

পরিষ্কার()

clear() এর ইতিহাসের কনসোল সাফ করে।

clear();

অনুলিপি (বস্তু)

copy(object) ক্লিপবোর্ডে নির্দিষ্ট বস্তুর একটি স্ট্রিং উপস্থাপনা কপি করে।

copy($0);

ডিবাগ (ফাংশন)

যখন নির্দিষ্ট ফাংশনটি কল করা হয়, তখন ডিবাগারকে আহ্বান করা হয় এবং উত্স প্যানেলে ফাংশনের ভিতরে বিরতি দেয় যা কোডের মধ্য দিয়ে ধাপে ধাপে এটিকে ডিবাগ করার অনুমতি দেয়।

debug(getData);

debug() দিয়ে একটি ফাংশনের ভিতরে ব্রেক করা।

ফাংশনে ব্রেকিং বন্ধ করতে undebug(fn) ব্যবহার করুন, অথবা সমস্ত ব্রেকপয়েন্ট নিষ্ক্রিয় করতে UI ব্যবহার করুন।

ব্রেকপয়েন্ট সম্পর্কে আরও তথ্যের জন্য, ব্রেকপয়েন্টের সাথে আপনার কোড পজ করুন দেখুন।

dir (বস্তু)

dir(object) সমস্ত নির্দিষ্ট বস্তুর বৈশিষ্ট্যগুলির একটি অবজেক্ট-স্টাইল তালিকা প্রদর্শন করে। এই পদ্ধতিটি কনসোল API এর console.dir() পদ্ধতির জন্য একটি শর্টকাট।

নিম্নলিখিত উদাহরণটি কমান্ড লাইনে সরাসরি document.body মূল্যায়ন এবং একই উপাদান প্রদর্শন করতে dir() ব্যবহার করার মধ্যে পার্থক্য দেখায়:

document.body;
dir(document.body);

dir() ফাংশন সহ এবং ছাড়া document.body লগিং করা।

আরও তথ্যের জন্য, কনসোল API-এ console.dir() এন্ট্রি দেখুন।

dirxml(অবজেক্ট)

dirxml(object) নির্দিষ্ট বস্তুর একটি XML উপস্থাপনা প্রিন্ট করে, যেমনটি এলিমেন্টস প্যানেলে দেখা যায়। এই পদ্ধতিটি console.dirxml() পদ্ধতির সমতুল্য।

পরিদর্শন (বস্তু/ফাংশন)

inspect(object/function) উপযুক্ত প্যানেলে নির্দিষ্ট উপাদান বা অবজেক্ট খোলে এবং নির্বাচন করে: হয় DOM এলিমেন্টের জন্য এলিমেন্ট প্যানেল অথবা জাভাস্ক্রিপ্ট হিপ অবজেক্টের জন্য প্রোফাইল প্যানেল।

নিম্নলিখিত উদাহরণটি এলিমেন্টস প্যানেলে document.body খোলে:

inspect(document.body);

inspect() দিয়ে একটি উপাদান পরিদর্শন করা হচ্ছে।

পরিদর্শন করার জন্য একটি ফাংশন পাস করার সময়, ফাংশনটি আপনার পরিদর্শনের জন্য উত্স প্যানেলে নথিটি খোলে।

getEventListeners(অবজেক্ট)

getEventListeners(object) নির্দিষ্ট বস্তুতে নিবন্ধিত ইভেন্ট শ্রোতাদের ফেরত দেয়। রিটার্ন মান হল একটি বস্তু যাতে প্রতিটি নিবন্ধিত ইভেন্ট টাইপের জন্য একটি অ্যারে থাকে (উদাহরণস্বরূপ click বা keydown )। প্রতিটি অ্যারের সদস্যরা এমন বস্তু যা প্রতিটি প্রকারের জন্য নিবন্ধিত শ্রোতাকে বর্ণনা করে। উদাহরণস্বরূপ, নিম্নলিখিত নথি বস্তুতে নিবন্ধিত সমস্ত ইভেন্ট শ্রোতাদের তালিকা করে:

getEventListeners(document);

getEventListeners() ব্যবহার করার আউটপুট।

যদি নির্দিষ্ট বস্তুতে একাধিক শ্রোতা নিবন্ধিত হয়, তাহলে অ্যারেতে প্রতিটি শ্রোতার জন্য একটি সদস্য থাকে। নিম্নলিখিত উদাহরণে, click ইভেন্টের জন্য নথি উপাদানে নিবন্ধিত দুটি ইভেন্ট শ্রোতা রয়েছে:

একাধিক শ্রোতা।

আপনি তাদের বৈশিষ্ট্যগুলি অন্বেষণ করতে এই বস্তুগুলির প্রতিটিকে আরও প্রসারিত করতে পারেন:

শ্রোতা বস্তুর প্রসারিত দৃশ্য।

আরও তথ্যের জন্য, অবজেক্টের বৈশিষ্ট্যগুলি পরিদর্শন করুন।

কী (বস্তু)

keys(object) নির্দিষ্ট বস্তুর অন্তর্গত বৈশিষ্ট্যের নাম সম্বলিত একটি অ্যারে প্রদান করে। একই বৈশিষ্ট্যের সংশ্লিষ্ট মান পেতে, values() ব্যবহার করুন।

উদাহরণস্বরূপ, ধরুন আপনার অ্যাপ্লিকেশন নিম্নলিখিত অবজেক্টটি সংজ্ঞায়িত করেছে:

let player = {
    "name": "Parzival",
    "number": 1,
    "state": "ready",
    "easterEggs": 3
};

অনুমান করা player গ্লোবাল নেমস্পেসে সংজ্ঞায়িত করা হয়েছে (সরলতার জন্য), টাইপিং keys(player) এবং values(player) কনসোলের ফলাফলে নিম্নরূপ:

কী() এবং মান() পদ্ধতির উদাহরণ।

মনিটর (ফাংশন)

যখন নির্দিষ্ট করা ফাংশনটি কল করা হয়, তখন একটি বার্তা কনসোলে লগ করা হয় যা ফাংশনের নামটি নির্দেশ করে যেটি আর্গুমেন্টের সাথে ফাংশনে পাঠানো হয় যখন এটি কল করা হয়েছিল।

function sum(x, y) {
  return x + y;
}
monitor(sum);

মনিটর() পদ্ধতির উদাহরণ।

নিরীক্ষণ বন্ধ করতে unmonitor(function) ব্যবহার করুন।

মনিটর ইভেন্ট (অবজেক্ট [, ঘটনা])

যখন নির্দিষ্ট ইভেন্টগুলির একটি নির্দিষ্ট বস্তুতে ঘটে, ইভেন্ট অবজেক্টটি কনসোলে লগ করা হয়। আপনি নিরীক্ষণের জন্য একটি একক ইভেন্ট, ইভেন্টের একটি অ্যারে, বা ইভেন্টগুলির একটি পূর্বনির্ধারিত সংগ্রহে ম্যাপ করা জেনেরিক ইভেন্টগুলির একটি "প্রকার" নির্দিষ্ট করতে পারেন। নীচের উদাহরণ দেখুন.

নিম্নলিখিতগুলি উইন্ডো অবজেক্টের সমস্ত রিসাইজ ইভেন্ট নিরীক্ষণ করে।

monitorEvents(window, "resize");

উইন্ডো রিসাইজ ইভেন্ট নিরীক্ষণ।

উইন্ডো অবজেক্টে "রিসাইজ" এবং "স্ক্রোল" ইভেন্ট উভয়ই নিরীক্ষণ করার জন্য নিম্নলিখিত একটি অ্যারে সংজ্ঞায়িত করে:

monitorEvents(window, ["resize", "scroll"])

আপনি উপলব্ধ ইভেন্টের একটি নির্দিষ্ট করতে পারেন "প্রকার", স্ট্রিং যা ইভেন্টের পূর্বনির্ধারিত সেটে মানচিত্র করে। নীচের সারণীটি উপলব্ধ ইভেন্টের প্রকার এবং তাদের সম্পর্কিত ইভেন্ট ম্যাপিংগুলি তালিকাভুক্ত করে:

ইভেন্টের ধরন এবং সংশ্লিষ্ট ম্যাপ করা ইভেন্ট
মাউস "মাউসডাউন", "মাউসআপ", "ক্লিক", "ডিবিএলক্লিক", "মাউসমোভ", "মাউসওভার", "মাউসআউট", "মাউসহুইল"
চাবি "কীডাউন", "কিআপ", "কিপ্রেস", "টেক্সটইনপুট"
স্পর্শ "টাচস্টার্ট", ​​"টাচমুভ", "টাচএন্ড", "টাচ ক্যান্সেল"
নিয়ন্ত্রণ "রিসাইজ", "স্ক্রোল", "জুম", "ফোকাস", "ব্লার", "সিলেক্ট", "পরিবর্তন", "জমা দিন", "রিসেট"

উদাহরণ স্বরূপ, এলিমেন্টস প্যানেলে বর্তমানে নির্বাচিত একটি ইনপুট টেক্সট ফিল্ডে নিম্নলিখিত "কী" ইভেন্ট টাইপ সমস্ত সংশ্লিষ্ট কী ইভেন্ট ব্যবহার করে।

monitorEvents($0, "key");

নীচে পাঠ্য ক্ষেত্রে একটি অক্ষর টাইপ করার পরে নমুনা আউটপুট:

মূল ঘটনা পর্যবেক্ষণ.

নিরীক্ষণ বন্ধ করতে unmonitorEvents(object[, events]) ব্যবহার করুন।

প্রোফাইল([নাম]) এবং প্রোফাইলএন্ড([নাম])

profile() একটি ঐচ্ছিক নামের সাথে একটি JavaScript CPU প্রোফাইলিং সেশন শুরু করে। profileEnd() প্রোফাইলটি সম্পূর্ণ করে এবং পারফরম্যান্স > প্রধান ট্র্যাকে ফলাফল প্রদর্শন করে।

প্রোফাইলিং শুরু করতে:

profile("Profile 1")

প্রোফাইলিং বন্ধ করতে এবং পারফরম্যান্স > প্রধান ট্র্যাকে ফলাফল দেখতে:

profileEnd("Profile 1")

পারফরম্যান্স > প্রধান ট্র্যাকের ফলাফল:

পারফরম্যান্সের প্রধান ট্র্যাকের প্রোফাইল 1।

প্রোফাইলগুলিও নেস্ট করা যেতে পারে। উদাহরণস্বরূপ, এটি যেকোনো ক্রমে কাজ করবে:

profile('A');
profile('B');
profileEnd('A');
profileEnd('B');

queryObjects(Constructor)

নির্দিষ্ট কনস্ট্রাক্টর দিয়ে তৈরি করা বস্তুর অ্যারে ফেরত দিতে কনসোল থেকে queryObjects(Constructor) কল করুন। যেমন:

  • queryObjects(Promise)Promise সমস্ত উদাহরণ প্রদান করে।
  • queryObjects(HTMLElement) । সমস্ত HTML উপাদান প্রদান করে।
  • queryObjects(foo) , যেখানে foo একটি শ্রেণীর নাম। new foo() মাধ্যমে ইনস্ট্যান্টিয়েট করা সমস্ত বস্তু ফেরত দেয়।

queryObjects() এর সুযোগ হল কনসোলে বর্তমানে নির্বাচিত এক্সিকিউশন প্রসঙ্গ।

টেবিল (ডেটা [, কলাম])

ঐচ্ছিক কলাম শিরোনাম সহ একটি ডেটা অবজেক্টে পাস করে টেবিল ফর্ম্যাটিং সহ অবজেক্ট ডেটা লগ করুন। এটি console.table() এর জন্য একটি শর্টকাট।

উদাহরণস্বরূপ, কনসোলে একটি টেবিল ব্যবহার করে নামের একটি তালিকা প্রদর্শন করতে, আপনি এটি করবেন:

let names = [
  { firstName: "John", lastName: "Smith" },
  { firstName: "Jane", lastName: "Doe" },
];
table(names);

টেবিল() পদ্ধতির উদাহরণ।

আনবাগ (ফাংশন)

undebug(function) নির্দিষ্ট ফাংশনের ডিবাগিং বন্ধ করে দেয় যাতে ফাংশনটি কল করা হলে, ডিবাগারকে আর ডাকা হয় না। এটি debug(fn) সাথে কনসার্টে ব্যবহৃত হয়।

undebug(getData);

আনমনিটর (ফাংশন)

unmonitor(function) নির্দিষ্ট ফাংশনের নিরীক্ষণ বন্ধ করে। এটি monitor(fn) সাথে কনসার্টে ব্যবহৃত হয়।

unmonitor(getData);

আনমনিটর ইভেন্টস(অবজেক্ট [, ঘটনা])

unmonitorEvents(object[, events]) নির্দিষ্ট বস্তু এবং ইভেন্টগুলির জন্য ইভেন্টগুলি পর্যবেক্ষণ করা বন্ধ করে। উদাহরণস্বরূপ, নিম্নলিখিতটি উইন্ডো অবজেক্টে সমস্ত ইভেন্ট পর্যবেক্ষণ বন্ধ করে দেয়:

unmonitorEvents(window);

আপনি বেছে বেছে একটি বস্তুর নির্দিষ্ট ইভেন্ট নিরীক্ষণ বন্ধ করতে পারেন। উদাহরণস্বরূপ, নিম্নলিখিত কোডটি বর্তমানে নির্বাচিত উপাদানের সমস্ত মাউস ইভেন্টগুলি পর্যবেক্ষণ করা শুরু করে এবং তারপরে "মাউসমুভ" ইভেন্টগুলি পর্যবেক্ষণ করা বন্ধ করে (সম্ভবত কনসোল আউটপুটে শব্দ কমাতে):

monitorEvents($0, "mouse");
unmonitorEvents($0, "mousemove");

মান (বস্তু)

values(object) নির্দিষ্ট বস্তুর অন্তর্গত সমস্ত বৈশিষ্ট্যের মান ধারণকারী একটি অ্যারে প্রদান করে।

let player = {
    "name": "Parzival",
    "number": 1,
    "state": "ready",
    "easterEggs": 3
};

values(player);

মানের ফলাফল (খেলোয়াড়)।