মানচিত্র জাভাস্ক্রিপ্ট API (প্রিভিউ) এ ওয়েব উপাদান

ওয়েব কম্পোনেন্ট হল একটি জনপ্রিয় W3C স্ট্যান্ডার্ড যা HTML, CSS, এবং JS কে কাস্টম এবং পুনঃব্যবহারযোগ্য HTML উপাদানে এনক্যাপসুলেট করে। এই পুনঃব্যবহারযোগ্য উপাদানগুলি কার্যকারিতার পারমাণবিক টুকরো থেকে শুরু করে আরও জটিল ব্যবসায়িক যুক্তি পর্যন্ত হতে পারে, যেমন একটি স্থানের জন্য তারকা রেটিং প্রদর্শন করা। এই নির্দেশিকা Maps JavaScript API-এ উপলব্ধ ওয়েব উপাদানগুলির বর্ণনা করে৷

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

শ্রোতা

এই ডকুমেন্টেশনটি ডিজাইন করা হয়েছে যাতে আপনি দ্রুত ওয়েব কম্পোনেন্টগুলির সাথে অ্যাপ্লিকেশনগুলি অন্বেষণ এবং বিকাশ শুরু করতে পারেন৷ আপনার HTML এবং CSS প্রোগ্রামিং ধারণার সাথে পরিচিত হওয়া উচিত।

একটি মানচিত্র প্রদর্শন করুন

ওয়েব উপাদান সম্পর্কে শেখা শুরু করার সবচেয়ে সহজ উপায় হল একটি উদাহরণ দেখা। নিম্নলিখিত উদাহরণটি সান জোসে এলাকার একটি মানচিত্র প্রদর্শন করে।

টাইপস্ক্রিপ্ট

// This example adds a map using web components.
function initMap(): void {
    console.log('Maps JavaScript API loaded.');
}

declare global {
    interface Window {
        initMap: () => void;
    }
}
window.initMap = initMap;

জাভাস্ক্রিপ্ট

// This example adds a map using web components.
function initMap() {
  console.log("Maps JavaScript API loaded.");
}

window.initMap = initMap;

সিএসএস

/* 
 * Always set the map height explicitly to define the size of the div element
 * that contains the map. 
 */
#map {
  height: 100%;
}

/* 
 * Optional: Makes the sample page fill the window. 
 */
html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
}

gmp-map {
  height: 400px;
}

এইচটিএমএল

<html>
  <head>
    <title>Add a Map Web Component</title>
    <script src="https://polyfill.io/v3/polyfill.min.js?features=default"></script>

    <link rel="stylesheet" type="text/css" href="./style.css" />
    <script type="module" src="./index.js"></script>
  </head>
  <body>
    <gmp-map
      center="37.4220656,-122.0840897"
      zoom="10"
      map-id="DEMO_MAP_ID"
    ></gmp-map>

    <!-- 
      The `defer` attribute causes the callback to execute after the full HTML
      document has been parsed. For non-blocking uses, avoiding race conditions,
      and consistent behavior across browsers, consider loading using Promises.
      See https://developers.google.com/maps/documentation/javascript/load-maps-js-api
      for more information.
      -->
    <script
      src="https://maps.googleapis.com/maps/api/js?key=AIzaSyB41DRUbKWJHPxaFjMAwdrzWzbVKartNGg&callback=initMap&v=beta"
      defer
    ></script>
  </body>
</html>

নমুনা চেষ্টা করুন

এই উদাহরণে লক্ষ করার মতো কয়েকটি জিনিস রয়েছে:

  1. মানচিত্র জাভাস্ক্রিপ্ট এপিআইকে অ্যাসিঙ্ক্রোনাস বলা হয়। API কখন লোড হয়েছে তা জানতে কলব্যাক ফাংশন ব্যবহার করা হয়।
  2. মানচিত্রের উপস্থাপনা <gmp-map> কাস্টম উপাদান দিয়ে সংজ্ঞায়িত করা হয়।
  3. মানচিত্র বৈশিষ্ট্য <gmp-map> কাস্টম উপাদানে বৈশিষ্ট্য নির্দিষ্ট করে সংজ্ঞায়িত করা হয়।
  4. স্টাইলিং কাস্টম উপাদানগুলিতে ইনলাইনে প্রয়োগ করা যেতে পারে বা একটি পৃথক CSS ফাইলে ঘোষণা করা যেতে পারে।

বেসম্যাপ স্টাইল করুন

একটি মানচিত্র আইডি একটি নির্দিষ্ট মানচিত্র শৈলী বা বৈশিষ্ট্যের সাথে যুক্ত একটি সনাক্তকারী। ঐচ্ছিক ক্লাউড কনফিগারেশন বৈশিষ্ট্যগুলির সুবিধা নিতে, ক্লাউড-ভিত্তিক মানচিত্রের স্টাইলিং DEMO_MAP_ID আপনার নিজস্ব মানচিত্র ID দিয়ে প্রতিস্থাপন করুন৷ কিভাবে একটি মানচিত্র ID তৈরি করতে হয় এবং একটি কাস্টম শৈলী কনফিগার করতে হয় তা জানতে, ক্লাউড-ভিত্তিক মানচিত্র স্টাইলিং- এ যান৷

মানচিত্রে চিহ্নিতকারী যোগ করুন

জটিল বিষয়বস্তু শ্রেণিবিন্যাস তৈরি করতে কেউ যেমন অন্তর্নির্মিত HTML ট্যাগগুলিকে নেস্ট করতে পারে, তেমনি এক বা একাধিক মানচিত্র মার্কার প্রদর্শনের জন্য একটি উপাদানের ভিতরে <gmp-advanced-marker> নেস্ট করতে পারে।

টাইপস্ক্রিপ্ট

// This example adds a map with markers, using web components.
function initMap(): void {
    console.log('Maps JavaScript API loaded.');
}

declare global {
    interface Window {
        initMap: () => void;
    }
}
window.initMap = initMap;

জাভাস্ক্রিপ্ট

// This example adds a map with markers, using web components.
function initMap() {
  console.log("Maps JavaScript API loaded.");
}

window.initMap = initMap;

সিএসএস

/* 
 * Always set the map height explicitly to define the size of the div element
 * that contains the map. 
 */
#map {
  height: 100%;
}

/* 
 * Optional: Makes the sample page fill the window. 
 */
html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
}

gmp-map {
  height: 400px;
}

এইচটিএমএল

<html>
  <head>
    <title>Add a Map with Markers using Web Components</title>
    <script src="https://polyfill.io/v3/polyfill.min.js?features=default"></script>

    <link rel="stylesheet" type="text/css" href="./style.css" />
    <script type="module" src="./index.js"></script>
  </head>
  <body>
    <gmp-map center="43.4142989,-124.2301242" zoom="4" map-id="DEMO_MAP_ID">
      <gmp-advanced-marker
        position="37.4220656,-122.0840897"
        title="Mountain View, CA"
      ></gmp-advanced-marker>
      <gmp-advanced-marker
        position="47.648994,-122.3503845"
        title="Seattle, WA"
      ></gmp-advanced-marker>
    </gmp-map>

    <!-- 
      The `defer` attribute causes the callback to execute after the full HTML
      document has been parsed. For non-blocking uses, avoiding race conditions,
      and consistent behavior across browsers, consider loading using Promises.
      See https://developers.google.com/maps/documentation/javascript/load-maps-js-api
      for more information.
      -->
    <script
      src="https://maps.googleapis.com/maps/api/js?key=AIzaSyB41DRUbKWJHPxaFjMAwdrzWzbVKartNGg&callback=initMap&libraries=marker&v=beta"
      defer
    ></script>
  </body>
</html>

নমুনা চেষ্টা করুন

এখানে আমরা <gmp-map> কাস্টম উপাদানের ভিতরে দুটি <gmp-advanced-marker> উপাদান যোগ করেছি। title জন্য পাঠ্য নির্দিষ্ট উপাদানের জন্য একটি অতিরিক্ত হোভার পাঠ্য এবং অ্যাক্সেসযোগ্যতা লেবেল প্রদান করে।

জাভাস্ক্রিপ্ট ইভেন্ট

ওয়েব কম্পোনেন্টের একটি প্রধান সুবিধা হল ব্যবহারের সহজলভ্যতা। কোডের কয়েকটি লাইনের সাহায্যে, কেউ জাভাস্ক্রিপ্ট বা উন্নত প্রোগ্রামিং সম্পর্কে সীমিত জ্ঞান সহ একটি মানচিত্র প্রদর্শন করতে পারে। একবার প্রয়োগ করা হলে, কোডটি অন্যান্য HTML উপাদানের পরিচিত নিদর্শন অনুসরণ করে। উদাহরণস্বরূপ, মানচিত্র বা অ্যাডভান্সড মার্কার অ্যাকশনগুলিতে প্রতিক্রিয়া জানাতে কেউ নেটিভ ব্রাউজার ইভেন্টিং সিস্টেম ব্যবহার করতে পারে, যেমন একটি মার্কার ক্লিক।

আপনার HTML-এ, একটি মার্কারকে ক্লিকযোগ্য করার জন্য gmp-advanced-marker উপাদানটিতে gmp-clickable বৈশিষ্ট্য সেট করুন। ক্লিক ইভেন্টগুলি পরিচালনা করতে advancedMarker.addEventListener ব্যবহার করুন।

টাইপস্ক্রিপ্ট

// This example adds a map using web components.
function initMap(): void {
  console.log('Maps JavaScript API loaded.');
  const advancedMarkers = document.querySelectorAll("#marker-click-event-example gmp-advanced-marker");
  for (const advancedMarker of advancedMarkers) {

    customElements.whenDefined(advancedMarker.localName).then(async () => {
      advancedMarker.addEventListener('gmp-click', async () => {

        const infoWindow = new google.maps.InfoWindow({
          //@ts-ignore
          content: advancedMarker.title,
        });
        infoWindow.open({
          //@ts-ignore
          anchor: advancedMarker
        });
      });
    });
  }
}

declare global {
  interface Window {
    initMap: () => void;
  }
}
window.initMap = initMap;

জাভাস্ক্রিপ্ট

// This example adds a map using web components.
function initMap() {
  console.log("Maps JavaScript API loaded.");

  const advancedMarkers = document.querySelectorAll(
    "#marker-click-event-example gmp-advanced-marker",
  );

  for (const advancedMarker of advancedMarkers) {
    customElements.whenDefined(advancedMarker.localName).then(async () => {
      advancedMarker.addEventListener("gmp-click", async () => {
        const infoWindow = new google.maps.InfoWindow({
          //@ts-ignore
          content: advancedMarker.title,
        });

        infoWindow.open({
          //@ts-ignore
          anchor: advancedMarker,
        });
      });
    });
  }
}

window.initMap = initMap;

সিএসএস

/* 
 * Always set the map height explicitly to define the size of the div element
 * that contains the map. 
 */
#map {
  height: 100%;
}

/* 
 * Optional: Makes the sample page fill the window. 
 */
html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
}

gmp-map {
  height: 400px;
}

এইচটিএমএল

<html>
  <head>
    <title>Add a Map Web Component with Events</title>
    <script src="https://polyfill.io/v3/polyfill.min.js?features=default"></script>

    <link rel="stylesheet" type="text/css" href="./style.css" />
    <script type="module" src="./index.js"></script>
  </head>
  <body>
    <gmp-map
      id="marker-click-event-example"
      center="43.4142989,-124.2301242"
      zoom="4"
      map-id="DEMO_MAP_ID"
    >
      <gmp-advanced-marker
        position="37.4220656,-122.0840897"
        title="Mountain View, CA"
        gmp-clickable
      ></gmp-advanced-marker>
      <gmp-advanced-marker
        position="47.648994,-122.3503845"
        title="Seattle, WA"
        gmp-clickable
      ></gmp-advanced-marker>
    </gmp-map>

    <!-- 
      The `defer` attribute causes the callback to execute after the full HTML
      document has been parsed. For non-blocking uses, avoiding race conditions,
      and consistent behavior across browsers, consider loading using Promises.
      See https://developers.google.com/maps/documentation/javascript/load-maps-js-api
      for more information.
      -->
    <script
      src="https://maps.googleapis.com/maps/api/js?key=AIzaSyB41DRUbKWJHPxaFjMAwdrzWzbVKartNGg&callback=initMap&libraries=marker&v=beta"
      defer
    ></script>
  </body>
</html>

নমুনা চেষ্টা করুন

এই উদাহরণে, Maps JavaScript API সম্পূর্ণরূপে লোড হয়ে গেলে initMap প্রয়োজনীয় কলব্যাক ফাংশন উপস্থাপন করে। কোডটি প্রতিটি মার্কারে শ্রোতাদের প্রতিষ্ঠা করে এবং প্রতিটি মার্কার ক্লিক করার সময় একটি তথ্য উইন্ডো উপস্থাপন করে।

এরপর কি