ReportingObserver: আপনার কোড স্বাস্থ্য জানুন

টিএল; ডিআর

শহরে একটি নতুন পর্যবেক্ষক আছে! ReportingObserver হল একটি নতুন API যা আপনাকে জানাতে দেয় যখন আপনার সাইট একটি অপসারিত API ব্যবহার করে বা ব্রাউজার হস্তক্ষেপে চলে:

const observer = new ReportingObserver(
  (reports, observer) => {
    for (const report of reports) {
      console.log(report.type, report.url, report.body);
    }
  },
  {buffered: true}
);

observer.observe();

আরও বিশ্লেষণের জন্য একটি ব্যাকএন্ড বা বিশ্লেষণ প্রদানকারীর কাছে প্রতিবেদন পাঠাতে কলব্যাক ব্যবহার করা যেতে পারে।

কেন যে দরকারী? এখন অবধি, অবচয় এবং হস্তক্ষেপের সতর্কতাগুলি শুধুমাত্র কনসোল বার্তা হিসাবে DevTools-এ উপলব্ধ ছিল৷ হস্তক্ষেপ, বিশেষ করে, শুধুমাত্র ডিভাইস এবং নেটওয়ার্ক অবস্থার মত বিভিন্ন বাস্তব-বিশ্বের সীমাবদ্ধতা দ্বারা ট্রিগার করা হয়। এইভাবে, স্থানীয়ভাবে কোনো সাইট ডেভেলপ/পরীক্ষা করার সময় আপনি এই বার্তাগুলি দেখতে পাবেন না। ReportingObserver এই সমস্যার সমাধান প্রদান করে। যখন ব্যবহারকারীরা বন্য অঞ্চলে সম্ভাব্য সমস্যার সম্মুখীন হন, তখন আমরা তাদের সম্পর্কে অবহিত হতে পারি।

ভূমিকা

কিছুক্ষণ আগে, আমি একটি ব্লগ পোস্ট লিখেছিলাম (" আপনার ওয়েব অ্যাপ পর্যবেক্ষণ করা ") কারণ আমি এটি আকর্ষণীয় বলে মনে করেছি যে একটি ওয়েব অ্যাপে ঘটে যাওয়া "স্টাফ" নিরীক্ষণের জন্য কতগুলি API আছে৷ উদাহরণস্বরূপ, এমন API রয়েছে যা DOM সম্পর্কে তথ্য পর্যবেক্ষণ করতে পারে: ResizeObserver , IntersectionObserver , MutationObserver । কর্মক্ষমতা পরিমাপ ক্যাপচার করার জন্য API আছে: PerformanceObserver । অন্যান্য API যেমন window.onerror এবং window.onunhandledrejection এমনকি কিছু ভুল হলে আমাদের জানান।

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

অবচয় এবং হস্তক্ষেপের জন্য DevTools কনসোল সতর্কতা।
DevTools কনসোলে ব্রাউজার-সূচিত সতর্কতা।

কেউ স্বাভাবিকভাবেই মনে করবে window.onerror এই সতর্কতাগুলো ক্যাপচার করে। এটা না! কারণ window.onerror সরাসরি ব্যবহারকারী এজেন্টের দ্বারা উত্পন্ন সতর্কতার জন্য ফায়ার করে না। এটি আপনার কোড চালানোর কারণে রানটাইম ত্রুটির (জেএস ব্যতিক্রম এবং সিনট্যাক্স ত্রুটি) জন্য ফায়ার করে।

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

এপিআই

এপিআই অন্যান্য "পর্যবেক্ষক" এপিআই যেমন IntersectionObserver এবং ResizeObserver এর মত নয়। আপনি এটি একটি কলব্যাক দিন; এটি আপনাকে তথ্য দেয়। কলব্যাক যে তথ্যটি গ্রহণ করে তা হল পৃষ্ঠার কারণে হওয়া সমস্যার একটি তালিকা:

const observer = new ReportingObserver((reports, observer) => {
  for (const report of reports) {
    // → report.type === 'deprecation'
    // → report.url === 'https://reporting-observer-api-demo.glitch.me'
    // → report.body.id === 'XMLHttpRequestSynchronousInNonWorkerOutsideBeforeUnload'
    // → report.body.message === 'Synchronous XMLHttpRequest is deprecated...'
    // → report.body.lineNumber === 11
    // → report.body.columnNumber === 22
    // → report.body.sourceFile === 'https://reporting-observer-api-demo.glitch.me'
    // → report.body.anticipatedRemoval === <JS_DATE_STR> or null
  }
});

observer.observe();

ফিল্টার করা রিপোর্ট

রিপোর্টগুলি শুধুমাত্র নির্দিষ্ট রিপোর্টের ধরনগুলি পর্যবেক্ষণ করার জন্য প্রি-ফিল্টার হতে পারে:

const observer = new ReportingObserver((reports, observer) => {
  ...
}, {types: ['deprecation']});

বাফার রিপোর্ট

যখন আপনি পর্যবেক্ষক তৈরি করার আগে তৈরি করা প্রতিবেদনগুলি দেখতে চান তখন buffered: true বিকল্পটি সত্যিই দরকারী:

const observer = new ReportingObserver((reports, observer) => {
  ...
}, {types: ['intervention'], buffered: true});

একটি ReportingObserver ব্যবহার করে এমন একটি লাইব্রেরি অলস-লোড করার মতো পরিস্থিতিতে এটি দুর্দান্ত। পর্যবেক্ষক দেরিতে যোগ করা হয়, কিন্তু আপনি পৃষ্ঠা লোডের আগে ঘটে যাওয়া কিছু মিস করবেন না

পর্যবেক্ষণ করা বন্ধ করুন

হ্যাঁ! এটি একটি disconnect পদ্ধতি আছে:

observer.disconnect(); // Stop the observer from collecting reports.

উদাহরণ

উদাহরণ - একটি বিশ্লেষণ প্রদানকারীকে ব্রাউজার হস্তক্ষেপের প্রতিবেদন করুন:

const observer = new ReportingObserver(
  (reports, observer) => {
    for (const report of reports) {
      sendReportToAnalytics(JSON.stringify(report.body));
    }
  },
  {types: ['intervention'], buffered: true}
);

observer.observe();

উদাহরণ - যখন API গুলি সরানো হবে তখন অবহিত করা হবে:

const observer = new ReportingObserver((reports, observer) => {
  for (const report of reports) {
    if (report.type === 'deprecation') {
      sendToBackend(`Using a deprecated API in ${report.body.sourceFile} which will be
                     removed on ${report.body.anticipatedRemoval}. Info: ${report.body.message}`);
    }
  }
});

observer.observe();

উপসংহার

ReportingObserver আপনাকে আপনার ওয়েব অ্যাপে সম্ভাব্য সমস্যাগুলি আবিষ্কার ও পর্যবেক্ষণ করার জন্য একটি অতিরিক্ত উপায় দেয়৷ এমনকি এটি আপনার কোডবেসের স্বাস্থ্য (বা এর অভাব) বোঝার জন্য একটি দরকারী টুল। একটি ব্যাকএন্ডে প্রতিবেদনগুলি পাঠান, ব্যবহারকারীরা আপনার সাইটে যে বাস্তব-বিশ্বের সমস্যাগুলি করছে সে সম্পর্কে জানুন, কোড আপডেট করুন, লাভ!

ভবিষ্যতের কাজ

ভবিষ্যতে, আমার আশা যে ReportingObserver JS-এ সব ধরনের সমস্যা ধরার জন্য ডি-ফ্যাক্টো API হয়ে উঠবে। আপনার অ্যাপে যা কিছু ভুল হয় তা ধরতে একটি API কল্পনা করুন:

  • ব্রাউজার হস্তক্ষেপ
  • অবজ্ঞা
  • বৈশিষ্ট্য নীতি লঙ্ঘন. crbug.com/867471 দেখুন।
  • JS ব্যতিক্রম এবং ত্রুটি (বর্তমানে window.onerror দ্বারা পরিসেবা করা হয়)।
  • আন-হ্যান্ডেলড জেএস প্রতিশ্রুতি প্রত্যাখ্যান (বর্তমানে window.onunhandledrejection দ্বারা পরিষেবা করা হয়)

ReportingObserver তাদের ওয়ার্কফ্লোতে একীভূত করার টুলস নিয়েও আমি উত্তেজিত। লাইটহাউস হল এমন একটি টুলের উদাহরণ যা ব্রাউজার অবচয়কে ইতিমধ্যেই ফ্ল্যাগ করে যখন আপনি এটির " অপ্রচলিত APIs এড়িয়ে যান " অডিট চালান:

অপসারিত API ব্যবহার করার জন্য Lighthouse অডিট ReportingObserver ব্যবহার করতে পারে।
অপসারিত API ব্যবহার করার জন্য Lighthouse অডিট ReportingObserver ব্যবহার করতে পারে।

লাইটহাউস বর্তমানে কনসোল বার্তাগুলি স্ক্র্যাপ করতে এবং বিকাশকারীদের কাছে এই সমস্যাগুলি প্রতিবেদন করতে DevTools প্রোটোকল ব্যবহার করে। পরিবর্তে, এটির সুগঠিত অবমূল্যায়ন প্রতিবেদন এবং anticipatedRemoval তারিখের মতো অতিরিক্ত মেটাডেটার জন্য ReportingObserver এ স্যুইচ করা আকর্ষণীয় হতে পারে।

অতিরিক্ত সম্পদ :

,

টিএল; ডিআর

শহরে একটি নতুন পর্যবেক্ষক আছে! ReportingObserver হল একটি নতুন API যা আপনাকে জানাতে দেয় যখন আপনার সাইট একটি অপসারিত API ব্যবহার করে বা ব্রাউজার হস্তক্ষেপে চলে:

const observer = new ReportingObserver(
  (reports, observer) => {
    for (const report of reports) {
      console.log(report.type, report.url, report.body);
    }
  },
  {buffered: true}
);

observer.observe();

আরও বিশ্লেষণের জন্য একটি ব্যাকএন্ড বা বিশ্লেষণ প্রদানকারীর কাছে প্রতিবেদন পাঠাতে কলব্যাক ব্যবহার করা যেতে পারে।

কেন যে দরকারী? এখন অবধি, অবচয় এবং হস্তক্ষেপের সতর্কতাগুলি শুধুমাত্র কনসোল বার্তা হিসাবে DevTools-এ উপলব্ধ ছিল৷ হস্তক্ষেপ, বিশেষ করে, শুধুমাত্র ডিভাইস এবং নেটওয়ার্ক অবস্থার মত বিভিন্ন বাস্তব-বিশ্বের সীমাবদ্ধতা দ্বারা ট্রিগার করা হয়। এইভাবে, স্থানীয়ভাবে কোনো সাইট ডেভেলপ/পরীক্ষা করার সময় আপনি এই বার্তাগুলি দেখতে পাবেন না। ReportingObserver এই সমস্যার সমাধান প্রদান করে। যখন ব্যবহারকারীরা বন্য অঞ্চলে সম্ভাব্য সমস্যার সম্মুখীন হন, তখন আমরা তাদের সম্পর্কে অবহিত হতে পারি।

ভূমিকা

কিছুক্ষণ আগে, আমি একটি ব্লগ পোস্ট লিখেছিলাম (" আপনার ওয়েব অ্যাপ পর্যবেক্ষণ করা ") কারণ আমি এটি আকর্ষণীয় বলে মনে করেছি যে একটি ওয়েব অ্যাপে ঘটে যাওয়া "স্টাফ" নিরীক্ষণের জন্য কতগুলি API আছে৷ উদাহরণস্বরূপ, এমন API রয়েছে যা DOM সম্পর্কে তথ্য পর্যবেক্ষণ করতে পারে: ResizeObserver , IntersectionObserver , MutationObserver । কর্মক্ষমতা পরিমাপ ক্যাপচার করার জন্য API আছে: PerformanceObserver । অন্যান্য API যেমন window.onerror এবং window.onunhandledrejection এমনকি কিছু ভুল হলে আমাদের জানান।

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

অবচয় এবং হস্তক্ষেপের জন্য DevTools কনসোল সতর্কতা।
DevTools কনসোলে ব্রাউজার-সূচিত সতর্কতা।

কেউ স্বাভাবিকভাবেই মনে করবে window.onerror এই সতর্কতাগুলো ক্যাপচার করে। এটা না! কারণ window.onerror সরাসরি ব্যবহারকারী এজেন্টের দ্বারা উত্পন্ন সতর্কতার জন্য ফায়ার করে না। এটি আপনার কোড চালানোর কারণে রানটাইম ত্রুটির (জেএস ব্যতিক্রম এবং সিনট্যাক্স ত্রুটি) জন্য ফায়ার করে।

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

এপিআই

এপিআই অন্যান্য "পর্যবেক্ষক" এপিআই যেমন IntersectionObserver এবং ResizeObserver এর মত নয়। আপনি এটি একটি কলব্যাক দিন; এটি আপনাকে তথ্য দেয়। কলব্যাক যে তথ্যটি গ্রহণ করে তা হল পৃষ্ঠার কারণে হওয়া সমস্যার একটি তালিকা:

const observer = new ReportingObserver((reports, observer) => {
  for (const report of reports) {
    // → report.type === 'deprecation'
    // → report.url === 'https://reporting-observer-api-demo.glitch.me'
    // → report.body.id === 'XMLHttpRequestSynchronousInNonWorkerOutsideBeforeUnload'
    // → report.body.message === 'Synchronous XMLHttpRequest is deprecated...'
    // → report.body.lineNumber === 11
    // → report.body.columnNumber === 22
    // → report.body.sourceFile === 'https://reporting-observer-api-demo.glitch.me'
    // → report.body.anticipatedRemoval === <JS_DATE_STR> or null
  }
});

observer.observe();

ফিল্টার করা রিপোর্ট

রিপোর্টগুলি শুধুমাত্র নির্দিষ্ট রিপোর্টের ধরনগুলি পর্যবেক্ষণ করার জন্য প্রি-ফিল্টার হতে পারে:

const observer = new ReportingObserver((reports, observer) => {
  ...
}, {types: ['deprecation']});

বাফার রিপোর্ট

যখন আপনি পর্যবেক্ষক তৈরি করার আগে তৈরি করা প্রতিবেদনগুলি দেখতে চান তখন buffered: true বিকল্পটি সত্যিই দরকারী:

const observer = new ReportingObserver((reports, observer) => {
  ...
}, {types: ['intervention'], buffered: true});

একটি ReportingObserver ব্যবহার করে এমন একটি লাইব্রেরি অলস-লোড করার মতো পরিস্থিতিতে এটি দুর্দান্ত। পর্যবেক্ষক দেরিতে যোগ করা হয়, কিন্তু আপনি পৃষ্ঠা লোডের আগে ঘটে যাওয়া কিছু মিস করবেন না

পর্যবেক্ষণ করা বন্ধ করুন

হ্যাঁ! এটি একটি disconnect পদ্ধতি আছে:

observer.disconnect(); // Stop the observer from collecting reports.

উদাহরণ

উদাহরণ - একটি বিশ্লেষণ প্রদানকারীকে ব্রাউজার হস্তক্ষেপের প্রতিবেদন করুন:

const observer = new ReportingObserver(
  (reports, observer) => {
    for (const report of reports) {
      sendReportToAnalytics(JSON.stringify(report.body));
    }
  },
  {types: ['intervention'], buffered: true}
);

observer.observe();

উদাহরণ - যখন API গুলি সরানো হবে তখন অবহিত করা হবে:

const observer = new ReportingObserver((reports, observer) => {
  for (const report of reports) {
    if (report.type === 'deprecation') {
      sendToBackend(`Using a deprecated API in ${report.body.sourceFile} which will be
                     removed on ${report.body.anticipatedRemoval}. Info: ${report.body.message}`);
    }
  }
});

observer.observe();

উপসংহার

ReportingObserver আপনাকে আপনার ওয়েব অ্যাপে সম্ভাব্য সমস্যাগুলি আবিষ্কার ও পর্যবেক্ষণ করার জন্য একটি অতিরিক্ত উপায় দেয়৷ এমনকি এটি আপনার কোডবেসের স্বাস্থ্য (বা এর অভাব) বোঝার জন্য একটি দরকারী টুল। একটি ব্যাকএন্ডে প্রতিবেদনগুলি পাঠান, ব্যবহারকারীরা আপনার সাইটে যে বাস্তব-বিশ্বের সমস্যাগুলি করছে সে সম্পর্কে জানুন, কোড আপডেট করুন, লাভ!

ভবিষ্যতের কাজ

ভবিষ্যতে, আমার আশা যে ReportingObserver JS-এ সব ধরনের সমস্যা ধরার জন্য ডি-ফ্যাক্টো API হয়ে উঠবে। আপনার অ্যাপে যা কিছু ভুল হয় তা ধরতে একটি API কল্পনা করুন:

  • ব্রাউজার হস্তক্ষেপ
  • অবজ্ঞা
  • বৈশিষ্ট্য নীতি লঙ্ঘন. crbug.com/867471 দেখুন।
  • JS ব্যতিক্রম এবং ত্রুটি (বর্তমানে window.onerror দ্বারা পরিসেবা করা হয়)।
  • আন-হ্যান্ডেলড জেএস প্রতিশ্রুতি প্রত্যাখ্যান (বর্তমানে window.onunhandledrejection দ্বারা পরিষেবা করা হয়)

ReportingObserver তাদের ওয়ার্কফ্লোতে একীভূত করার টুলস নিয়েও আমি উত্তেজিত। লাইটহাউস হল এমন একটি টুলের উদাহরণ যা ব্রাউজার অবচয়কে ইতিমধ্যেই ফ্ল্যাগ করে যখন আপনি এটির " অপ্রচলিত APIs এড়িয়ে যান " অডিট চালান:

অপসারিত API ব্যবহার করার জন্য Lighthouse অডিট ReportingObserver ব্যবহার করতে পারে।
অপসারিত API ব্যবহার করার জন্য Lighthouse অডিট ReportingObserver ব্যবহার করতে পারে।

লাইটহাউস বর্তমানে কনসোল বার্তাগুলি স্ক্র্যাপ করতে এবং বিকাশকারীদের কাছে এই সমস্যাগুলি প্রতিবেদন করতে DevTools প্রোটোকল ব্যবহার করে। পরিবর্তে, এটির সুগঠিত অবমূল্যায়ন প্রতিবেদন এবং anticipatedRemoval তারিখের মতো অতিরিক্ত মেটাডেটার জন্য ReportingObserver এ স্যুইচ করা আকর্ষণীয় হতে পারে।

অতিরিক্ত সম্পদ :