প্রকাশিত: জুলাই 29, 2021
ট্যাগ হল থার্ড-পার্টি কোডের স্নিপেট যা একটি সাইটে ঢোকানো হয়, সাধারণত ট্যাগ ম্যানেজার দিয়ে। ট্যাগগুলি সাধারণত মার্কেটিং এবং বিশ্লেষণের জন্য ব্যবহৃত হয়।
ট্যাগ এবং ট্যাগ পরিচালকদের কর্মক্ষমতা প্রভাব বিভিন্ন সাইট জুড়ে ব্যাপকভাবে পরিবর্তিত হয়। ট্যাগ ম্যানেজারদের একটি খামের সাথে তুলনা করা যেতে পারে: ট্যাগ ম্যানেজার একটি পাত্র সরবরাহ করে, কিন্তু আপনি এটি কী দিয়ে পূরণ করবেন এবং আপনি কীভাবে এটি ব্যবহার করবেন তা বেশিরভাগই আপনার উপর নির্ভর করে।
এখানে, আমরা কর্মক্ষমতা এবং মূল ওয়েব ভাইটালগুলির জন্য ট্যাগ এবং ট্যাগ পরিচালকদের অপ্টিমাইজ করার কৌশল নিয়ে আলোচনা করি। যদিও এই নথিটি Google ট্যাগ ম্যানেজারকে উল্লেখ করে, আলোচিত অনেক ধারণা অন্যান্য ট্যাগ পরিচালকদের ক্ষেত্রে প্রযোজ্য।
কোর ওয়েব ভাইটালসের উপর প্রভাব
ট্যাগ ম্যানেজাররা প্রায়ই আপনার পৃষ্ঠাটি দ্রুত লোড করতে এবং এটিকে প্রতিক্রিয়াশীল রাখতে প্রয়োজনীয় সংস্থানগুলি ব্যবহার করে আপনার মূল ওয়েব ভাইটালগুলিকে পরোক্ষভাবে প্রভাবিত করতে পারে। ব্যান্ডউইথ আপনার সাইটের জন্য ট্যাগ ম্যানেজার জাভাস্ক্রিপ্ট ডাউনলোড করতে খরচ করা যেতে পারে, বা এর পরবর্তী কলগুলি। মূল থ্রেডে CPU সময় ট্যাগ ম্যানেজার এবং ট্যাগের মধ্যে থাকা জাভাস্ক্রিপ্ট মূল্যায়ন এবং কার্যকর করার জন্য ব্যয় করা যেতে পারে।
সবচেয়ে বড় কন্টেন্টফুল পেইন্ট (LCP) গুরুত্বপূর্ণ পৃষ্ঠা লোডের সময় ব্যান্ডউইথ বিতর্কের জন্য ঝুঁকিপূর্ণ। উপরন্তু, প্রধান থ্রেড ব্লক করা LCP রেন্ডারের সময়কে বিলম্বিত করতে পারে।
ক্রমবর্ধমান লেআউট শিফট (CLS) প্রভাবিত হতে পারে, হয় প্রথম রেন্ডারের আগে গুরুত্বপূর্ণ সংস্থান লোড করতে দেরি করে, অথবা ট্যাগ ম্যানেজারদের দ্বারা পৃষ্ঠায় সামগ্রী প্রবেশ করানো হয়৷
নেক্সট পেইন্টের সাথে ইন্টারঅ্যাকশন (আইএনপি) মূল থ্রেডে সিপিইউ বিতর্কের জন্য সংবেদনশীল, এবং আমরা ট্যাগ ম্যানেজার এবং দরিদ্র INP স্কোরের মধ্যে একটি সম্পর্ক দেখেছি।
সঠিক ট্যাগ টাইপ নির্বাচন করুন
কর্মক্ষমতা উপর ট্যাগ প্রভাব ট্যাগ ধরনের দ্বারা পরিবর্তিত হয়. সাধারণভাবে বলতে গেলে, ইমেজ ট্যাগগুলি ("পিক্সেল") সবচেয়ে কার্যকরী, তার পরে কাস্টম টেমপ্লেট এবং সবশেষে, কাস্টম এইচটিএমএল ট্যাগ৷ বিক্রেতা ট্যাগগুলি তাদের অনুমতি দেওয়া কার্যকারিতার উপর নির্ভর করে পরিবর্তিত হয়।
মনে রাখবেন যে আপনি কীভাবে একটি ট্যাগ ব্যবহার করেন তা এর কার্যকারিতার প্রভাবকে ব্যাপকভাবে প্রভাবিত করে। "পিক্সেল" অনেক বেশি পারফরম্যান্স করে কারণ এই ট্যাগ টাইপের প্রকৃতি তাদের কীভাবে ব্যবহার করা যেতে পারে তার উপর কঠোর বিধিনিষেধ আরোপ করে; কাস্টম এইচটিএমএল ট্যাগগুলি সর্বদা কর্মক্ষমতার জন্য খারাপ হয় না, তবে তারা ব্যবহারকারীদের যে স্বাধীনতা প্রদান করে তার কারণে তাদের কার্যক্ষমতার জন্য খারাপ এমনভাবে অপব্যবহার করা সহজ হতে পারে।
ট্যাগ সম্পর্কে চিন্তা করার সময়, স্কেলটি মনে রাখবেন: যে কোনও একক ট্যাগের কার্যকারিতা প্রভাব নগণ্য হতে পারে—কিন্তু একই পৃষ্ঠায় দশ বা শত শত ট্যাগ ব্যবহার করা হলে তা তাৎপর্যপূর্ণ হতে পারে।
সব স্ক্রিপ্ট ট্যাগ ম্যানেজার দিয়ে লোড করা উচিত নয়
ট্যাগ ম্যানেজার সাধারণত রিসোর্স লোড করার সর্বোত্তম উপায় নয় যা ব্যবহারকারীর অভিজ্ঞতার অবিলম্বে চাক্ষুষ বা কার্যকরী দিকগুলি প্রয়োগ করে, যেমন কুকি নোটিশ, হিরো ছবি বা সাইটের বৈশিষ্ট্যগুলি। এই সংস্থানগুলি লোড করার জন্য একটি ট্যাগ ম্যানেজার ব্যবহার করা সাধারণত তাদের বিতরণে বিলম্ব করে। এটি ব্যবহারকারীর অভিজ্ঞতার জন্য খারাপ এবং এটি LCP এবং CLS-এর মতো মেট্রিক্সও বাড়াতে পারে।
উপরন্তু, কিছু ব্যবহারকারী ট্যাগ ম্যানেজার ব্লক. UX বৈশিষ্ট্যগুলি বাস্তবায়নের জন্য একটি ট্যাগ ম্যানেজার ব্যবহার করার ফলে আপনার কিছু ব্যবহারকারীর জন্য একটি ভাঙা ওয়েবসাইট হতে পারে৷
কাস্টম এইচটিএমএল ট্যাগের সাথে সতর্ক থাকুন
কাস্টম এইচটিএমএল ট্যাগগুলি বহু বছর ধরে রয়েছে এবং বেশিরভাগ সাইটে ব্যাপকভাবে ব্যবহৃত হয়৷ কাস্টম এইচটিএমএল ট্যাগ আপনাকে কিছু বিধিনিষেধ সহ আপনার নিজস্ব কোড প্রবেশ করার অনুমতি দেয় কারণ নাম থাকা সত্ত্বেও, এই ট্যাগের প্রধান ব্যবহার হল একটি পৃষ্ঠায় কাস্টম <script>
উপাদান যোগ করা।
কাস্টম HTML ট্যাগগুলি বিভিন্ন উপায়ে ব্যবহার করা যেতে পারে এবং তাদের কর্মক্ষমতা প্রভাব উল্লেখযোগ্যভাবে পরিবর্তিত হয়। আপনার সাইটের পারফরম্যান্স পরিমাপ করার সময়, সচেতন হোন যে বেশিরভাগ টুলগুলি ট্যাগ ম্যানেজারকে ইঞ্জেকশন দেওয়ার জন্য একটি কাস্টম এইচটিএমএল ট্যাগের কার্যক্ষমতার প্রভাবকে দায়ী করে — ট্যাগটির পরিবর্তে।
কাস্টম HTML ট্যাগ পার্শ্ববর্তী পৃষ্ঠায় একটি উপাদান সন্নিবেশ করতে পারে। পৃষ্ঠায় উপাদান ঢোকানোর কাজটি পারফরম্যান্স সমস্যার একটি উৎস হতে পারে এবং কিছু ক্ষেত্রে লেআউট পরিবর্তনের কারণও হতে পারে।
- বেশিরভাগ পরিস্থিতিতে, যদি একটি উপাদান পৃষ্ঠায় ঢোকানো হয়, ব্রাউজারটিকে অবশ্যই পৃষ্ঠায় প্রতিটি আইটেমের আকার এবং অবস্থান পুনঃগণনা করতে হবে। এই প্রক্রিয়াটি লেআউট হিসাবে পরিচিত। একটি একক লেআউটের কর্মক্ষমতা প্রভাব ন্যূনতম, কিন্তু যখন এটি অত্যধিক ঘটে তখন এটি কর্মক্ষমতা সমস্যার একটি উৎস হয়ে উঠতে পারে। এই ঘটনার প্রভাব নিম্ন-প্রান্তের ডিভাইস এবং উচ্চ সংখ্যক DOM উপাদান সহ পৃষ্ঠাগুলিতে বেশি।
- আশেপাশের এলাকা ইতিমধ্যে রেন্ডার করার পরে যদি একটি দৃশ্যমান পৃষ্ঠা উপাদান DOM-এ ঢোকানো হয়, তাহলে এটি একটি লেআউট পরিবর্তনের কারণ হতে পারে। এই ঘটনাটি ট্যাগ ম্যানেজারদের জন্য অনন্য নয়-তবে, কারণ ট্যাগগুলি সাধারণত পৃষ্ঠার অন্যান্য অংশের তুলনায় পরে লোড হয়, তাই তাদের জন্য আশেপাশের পৃষ্ঠাটি ইতিমধ্যে রেন্ডার হওয়ার পরে DOM-এ ঢোকানো সাধারণ।
কাস্টম টেমপ্লেট ব্যবহার করুন
কাস্টম টেমপ্লেটগুলি কাস্টম এইচটিএমএল ট্যাগের মতো কিছু ক্রিয়াকলাপকে সমর্থন করে তবে জাভাস্ক্রিপ্টের একটি স্যান্ডবক্সড সংস্করণের উপর নির্মিত যা স্ক্রিপ্ট ইনজেকশন এবং পিক্সেল ইনজেকশনের মতো সাধারণ ব্যবহারের ক্ষেত্রে API প্রদান করে। নামটি বোঝায়, তারা একটি টেমপ্লেট তৈরি করার অনুমতি দেয়, এমন একজন শক্তি ব্যবহারকারীর দ্বারা, যারা কর্মক্ষমতা মাথায় রেখে এটি তৈরি করতে পারে। কম প্রযুক্তিগত ব্যবহারকারীরা তারপর টেমপ্লেট ব্যবহার করতে পারেন। এটি প্রায়ই সম্পূর্ণ কাস্টম HTML অ্যাক্সেস প্রদানের চেয়ে নিরাপদ।
কাস্টম টেমপ্লেটগুলিতে আরোপিত বৃহত্তর বিধিনিষেধের কারণে, এই ট্যাগগুলির কার্যকারিতা বা নিরাপত্তা সমস্যাগুলি প্রদর্শন করার সম্ভাবনা অনেক কম। এই একই কারণে, কাস্টম টেমপ্লেটগুলি সমস্ত ব্যবহারের ক্ষেত্রে কাজ করে না।
সঠিকভাবে স্ক্রিপ্ট ইনজেক্ট করুন
একটি স্ক্রিপ্ট ইনজেক্ট করার জন্য একটি ট্যাগ ম্যানেজার ব্যবহার করা একটি খুব সাধারণ ব্যবহারের ক্ষেত্রে। এটি করার প্রস্তাবিত উপায় হল একটি কাস্টম টেমপ্লেট এবং injectScript
API ব্যবহার করা।
একটি বিদ্যমান কাস্টম HTML ট্যাগ রূপান্তর করতে injectScript API ব্যবহার করার তথ্যের জন্য, একটি বিদ্যমান ট্যাগ রূপান্তর দেখুন।
আপনি যদি একটি কাস্টম HTML ট্যাগ ব্যবহার করতে চান, মনে রাখবেন:
- লাইব্রেরি এবং বড় তৃতীয় পক্ষের স্ক্রিপ্টগুলিকে একটি স্ক্রিপ্ট ট্যাগ দিয়ে লোড করা উচিত (উদাহরণস্বরূপ,
<script src="external-scripts.js">
) যা একটি বহিরাগত ফাইল ডাউনলোড করে, স্ক্রিপ্টের বিষয়বস্তু সরাসরি ট্যাগে কপি-পেস্ট করার পরিবর্তে। যদিও<script>
ট্যাগের ব্যবহার ভুলে যাওয়া স্ক্রিপ্টের বিষয়বস্তু ডাউনলোড করার জন্য একটি পৃথক রাউন্ড-ট্রিপ বাদ দেয়, এই অনুশীলনটি কন্টেইনারের আকার বাড়ায় এবং ব্রাউজার দ্বারা স্ক্রিপ্টটিকে আলাদাভাবে ক্যাশে করা থেকে বাধা দেয়। - অনেক বিক্রেতা তাদের
<script>
ট্যাগ<head>
এর উপরে রাখার পরামর্শ দেন। যাইহোক, ট্যাগ ম্যানেজার দিয়ে লোড করা স্ক্রিপ্টগুলির জন্য, এটি প্রায়শই অপ্রয়োজনীয়। বেশিরভাগ পরিস্থিতিতে, ট্যাগ ম্যানেজার কার্যকর করার সময় ব্রাউজার ইতিমধ্যেই<head>
পার্সিং শেষ করেছে।
পিক্সেল ব্যবহার করুন
কখনও কখনও, তৃতীয় পক্ষের স্ক্রিপ্টগুলিকে চিত্র বা আইফ্রেম পিক্সেল দিয়ে প্রতিস্থাপন করা যেতে পারে। তাদের স্ক্রিপ্ট-ভিত্তিক প্রতিরূপের তুলনায়, পিক্সেলগুলি কম কার্যকারিতা সমর্থন করতে পারে, তাই প্রায়শই কম-পছন্দের বাস্তবায়ন হিসাবে দেখা হয়। যাইহোক, যখন ট্যাগ ম্যানেজারগুলির ভিতরে ব্যবহার করা হয়, তখন পিক্সেলগুলি আরও গতিশীল হতে পারে কারণ তারা ট্রিগারগুলিতে ফায়ার করতে পারে এবং বিভিন্ন ভেরিয়েবল পাস করতে পারে।
পিক্সেল হল সবচেয়ে পারফরম্যান্স এবং সুরক্ষিত ধরনের ট্যাগ কারণ এটি ফায়ার করার পরে কোন জাভাস্ক্রিপ্ট এক্সিকিউশন নেই। পিক্সেলগুলির একটি খুব ছোট সংস্থান আকার (1 KB-এর কম) এবং লেআউট পরিবর্তনের কারণ হয় না৷
পিক্সেলের জন্য তাদের সমর্থন সম্পর্কে আরও তথ্যের জন্য আপনার তৃতীয়-পক্ষ প্রদানকারীর সাথে যোগাযোগ করুন। উপরন্তু, আপনি একটি <noscript>
ট্যাগের জন্য তাদের কোড পরিদর্শন করার চেষ্টা করতে পারেন। যদি কোনো বিক্রেতা পিক্সেল সমর্থন করে, তারা প্রায়ই <noscript>
ট্যাগের মধ্যে পিক্সেল অন্তর্ভুক্ত করে।
পিক্সেলের বিকল্প
পিক্সেলগুলি মূলত জনপ্রিয় হয়ে ওঠে কারণ এক সময়ে সার্ভারের প্রতিক্রিয়া প্রাসঙ্গিক নয় এমন পরিস্থিতিতে একটি HTTP অনুরোধ করার সবচেয়ে সস্তা এবং সবচেয়ে নির্ভরযোগ্য উপায়গুলির মধ্যে একটি ছিল (উদাহরণস্বরূপ, বিশ্লেষণ প্রদানকারীদের কাছে ডেটা পাঠানোর সময়)। navigator.sendBeacon()
এবং fetch() keepalive
API-গুলি একই ব্যবহারের ক্ষেত্রে সমাধান করার জন্য ডিজাইন করা হয়েছে কিন্তু পিক্সেলের তুলনায় যুক্তিযুক্তভাবে বেশি নির্ভরযোগ্য।
পিক্সেল ব্যবহার করা চালিয়ে যাওয়ার সাথে কোনও ভুল নেই—এগুলি ভালভাবে সমর্থিত এবং ন্যূনতম কার্যক্ষমতার প্রভাব রয়েছে৷ যাইহোক, আপনি যদি নিজের বীকন তৈরি করেন তবে এই APIগুলির মধ্যে একটি ব্যবহার করে বিবেচনা করা মূল্যবান।
sendBeacon()
navigator.sendBeacon()
API এমন পরিস্থিতিতে ওয়েব সার্ভারে অল্প পরিমাণে ডেটা পাঠানোর জন্য ডিজাইন করা হয়েছে যেখানে সার্ভারের প্রতিক্রিয়া কোন ব্যাপার না।
const url = "https://example.com/analytics";
const data = JSON.stringify({
event: "checkout",
time: performance.now()
});
navigator.sendBeacon(url, data);
sendBeacon()
একটি সীমিত API রয়েছে: এটি শুধুমাত্র POST অনুরোধগুলিকে সমর্থন করে এবং কাস্টম হেডার সেট করা সমর্থন করে না। এটি সমস্ত আধুনিক ব্রাউজার দ্বারা সমর্থিত ।
এপিআই keepalive
আনুন
keepalive
হল একটি পতাকা যা ফেচ এপিআইকে ইভেন্ট রিপোর্টিং এবং বিশ্লেষণের মতো নন-ব্লকিং অনুরোধ করতে ব্যবহার করতে দেয়। এটি keepalive অন্তর্ভুক্ত করে ব্যবহার করা হয়: fetch()
এ পাস করা প্যারামিটারে keepalive: true
।
const url = "https://example.com/analytics";
const data = JSON.stringify({
event: "checkout",
time: performance.now()
});
fetch(url, {
method: 'POST',
body: data,
keepalive: true
});
যদি fetch() keepalive
এবং sendBeacon()
খুব একই রকম মনে হয়, এর কারণ হল তারা। আসলে, ক্রোমিয়াম ব্রাউজারে, sendBeacon()
এখন fetch() keepalive
এর উপর নির্মিত।
fetch() keepalive
এবং sendBeacon()
এর মধ্যে নির্বাচন করার সময়, আপনার প্রয়োজনীয় বৈশিষ্ট্য এবং ব্রাউজার সমর্থন বিবেচনা করা গুরুত্বপূর্ণ। fetch() API উল্লেখযোগ্যভাবে আরো নমনীয়; যাইহোক, keepalive
sendBeacon()
চেয়ে কম ব্রাউজার সমর্থন রয়েছে।
ট্যাগ কি করে তা বুঝুন
ট্যাগগুলি প্রায়ই তৃতীয় পক্ষের বিক্রেতার দ্বারা প্রদত্ত নির্দেশিকা অনুসরণ করে তৈরি করা হয়। একজন বিক্রেতার কোড কী করে তা যদি অস্পষ্ট হয়, তাহলে জানেন এমন কাউকে জিজ্ঞাসা করুন। একটি দ্বিতীয় মতামত পাওয়া একটি ট্যাগ কর্মক্ষমতা বা নিরাপত্তা সমস্যা তৈরি করার সম্ভাবনা আছে কিনা তা সনাক্ত করতে সাহায্য করতে পারে।
আমরা ট্যাগ ম্যানেজারে মালিকের সাথে ট্যাগ লেবেল করার পরামর্শ দিই। কার ট্যাগের মালিক তা ভুলে যাওয়া সহজ, যা কিছু ভেঙ্গে গেলে অপসারণের ভয় দেখায়!
ট্রিগার
উচ্চ-স্তরে, অপ্টিমাইজিং ট্যাগ ট্রিগারগুলি সাধারণত প্রয়োজনের চেয়ে বেশি ট্যাগগুলিকে ট্রিগার না করার বিষয়টি নিশ্চিত করা এবং একটি ট্রিগার বেছে নেওয়া যা ব্যবসার প্রয়োজনের সাথে পারফরম্যান্স খরচের ভারসাম্য বজায় রাখে।
ট্রিগার হল জাভাস্ক্রিপ্ট কোড যা ট্যাগ ম্যানেজারের আকার এবং এক্সিকিউশন খরচ বাড়ায়। যদিও বেশিরভাগ ট্রিগার ছোট, ক্রমবর্ধমান প্রভাব যোগ করতে পারে। উদাহরণস্বরূপ, বেশ কয়েকটি ক্লিক ইভেন্ট বা টাইমার ট্রিগার থাকা ট্যাগ ম্যানেজারের কাজের চাপকে নাটকীয়ভাবে বাড়িয়ে তুলতে পারে।
একটি উপযুক্ত ট্রিগার ইভেন্ট চয়ন করুন
একটি ট্যাগের কর্মক্ষমতা প্রভাব পরিবর্তিত হতে পারে। সাধারণভাবে, একটি ট্যাগ যত তাড়াতাড়ি ফায়ার হয়, তত বেশি এটি কার্যক্ষমতাকে প্রভাবিত করে। প্রাথমিক পৃষ্ঠা লোডের সময় সংস্থানগুলি সাধারণত সীমাবদ্ধ থাকে এবং তাই একটি নির্দিষ্ট সংস্থান (বা ট্যাগ) লোড করা বা কার্যকর করা অন্য কিছু থেকে সংস্থানগুলিকে সরিয়ে নেয়।
যদিও সমস্ত ট্যাগের জন্য উপযুক্ত ট্রিগার বাছাই করা গুরুত্বপূর্ণ, এটি বিশেষ করে ট্যাগগুলির জন্য গুরুত্বপূর্ণ যেগুলি বড় সম্পদ লোড করে বা দীর্ঘ স্ক্রিপ্ট চালায়।
ট্যাগগুলি পৃষ্ঠা দর্শনে ট্রিগার করা যেতে পারে (সাধারণত Page load
, DOM Ready
, Window Loaded
) বা একটি কাস্টম ইভেন্টের উপর ভিত্তি করে। পৃষ্ঠা লোডকে প্রভাবিত না করতে, Window Loaded
পরে অপ্রয়োজনীয় ট্যাগগুলি ফায়ার করুন।
কাস্টম ইভেন্ট ব্যবহার করুন
Google ট্যাগ ম্যানেজারের অন্তর্নির্মিত ট্রিগারগুলির দ্বারা কভার করা হয়নি এমন পৃষ্ঠা ইভেন্টগুলির প্রতিক্রিয়া হিসাবে ট্রিগারগুলি ফায়ার করতে কাস্টম ইভেন্টগুলি ব্যবহার করুন৷ উদাহরণস্বরূপ, অনেক ট্যাগ পেজ ভিউ ট্রিগার ব্যবহার করে। যাইহোক, DOM Ready
এবং Window Loaded
মধ্যে সময় দীর্ঘ হতে পারে, এইভাবে ট্যাগ ফায়ার হওয়ার সময় সূক্ষ্ম সুর করা কঠিন করে তোলে। কাস্টম ইভেন্ট এই সমস্যার সমাধান হতে পারে।
প্রথমে একটি কাস্টম ইভেন্ট ট্রিগার তৈরি করুন এবং এই ট্রিগারটি ব্যবহার করতে আপনার ট্যাগ আপডেট করুন৷
ট্রিগার ফায়ার করতে, সংশ্লিষ্ট ইভেন্টটিকে ডেটা স্তরে পুশ করুন।
// Custom event trigger that fires after 2 seconds
setTimeout(() => {
dataLayer.push({
'event' : 'my-custom-event'
});
}, 2000);
নির্দিষ্ট ট্রিগার শর্ত ব্যবহার করুন
অপ্রয়োজনীয় ট্যাগ ফায়ারিং এড়াতে নির্দিষ্ট ট্রিগার শর্ত সংজ্ঞায়িত করুন। এটি করার সবচেয়ে সহজ এবং কার্যকর উপায়গুলির মধ্যে একটি হল নিশ্চিত করা যে একটি ট্যাগ শুধুমাত্র সেই পৃষ্ঠাগুলিতেই ফায়ার হয় যেখানে এটি আসলে ব্যবহৃত হয়৷
অন্তর্নির্মিত ভেরিয়েবলগুলি ট্যাগ ফায়ারিং সীমিত করতে ট্রিগার অবস্থার মধ্যে অন্তর্ভুক্ত করা যেতে পারে।
একটি উপযুক্ত সময়ে আপনার ট্যাগ ম্যানেজার লোড করুন
ট্যাগ ম্যানেজার নিজেই লোড হলে আপনি সামঞ্জস্য করে কর্মক্ষমতা উন্নত করতে পারেন। ট্রিগারগুলি, যেভাবেই কনফিগার করা হোক না কেন, ট্যাগ ম্যানেজার লোড না হওয়া পর্যন্ত ফায়ার করতে পারে না৷ আপনি ট্যাগ ম্যানেজার লোড করার সময় পরীক্ষা করুন, কারণ এটি সমান বা বেশি প্রভাব ফেলতে পারে। এই সিদ্ধান্ত একটি পৃষ্ঠায় সমস্ত ট্যাগ প্রভাবিত করে.
ট্যাগ ম্যানেজারটি পরে লোড করার মাধ্যমে, আপনি ভবিষ্যতের পারফরম্যান্সের সমস্যাগুলি এড়াতে পারেন, কারণ এটি অসাবধানতাবশত একটি ট্যাগ খুব তাড়াতাড়ি লোড হওয়া প্রতিরোধ করে৷
ভেরিয়েবল
পৃষ্ঠা থেকে ডেটা পড়তে ভেরিয়েবল ব্যবহার করুন। তারা ট্রিগার এবং ট্যাগ নিজেদের মধ্যে দরকারী.
ট্রিগারের মতো, ভেরিয়েবলগুলি ট্যাগ ম্যানেজারে জাভাস্ক্রিপ্ট কোড যোগ করে এবং এর ফলে কার্যক্ষমতার সমস্যা হতে পারে। ভেরিয়েবল তুলনামূলকভাবে ছোট হতে পারে, যেমন ইউআরএলের কিছু অংশ পড়ার জন্য কোড, কুকিজ, ডেটা লেয়ার বা DOM। তারা কাস্টম জাভাস্ক্রিপ্টও অন্তর্ভুক্ত করতে পারে যার সীমাহীন ক্ষমতা (এবং আকার) রয়েছে।
পরিবর্তনশীল ব্যবহারকে ন্যূনতম রাখুন, কারণ ট্যাগ ম্যানেজার দ্বারা ক্রমাগত মূল্যায়ন করা হয়। ট্যাগ ম্যানেজার স্ক্রিপ্টের আকার এবং এটি ব্যবহার করা প্রক্রিয়াকরণের সময় উভয়ই কমাতে আর ব্যবহার করা হয় না এমন পুরানো ভেরিয়েবলগুলি সরান৷
ট্যাগ ব্যবস্থাপনা
ট্যাগগুলি দক্ষতার সাথে ব্যবহার করা কর্মক্ষমতা সমস্যাগুলির ঝুঁকি হ্রাস করে৷
ডেটা স্তর ব্যবহার করুন
ডাটা লেয়ার হল একটি জাভাস্ক্রিপ্ট অ্যারে অবজেক্ট যাতে পৃষ্ঠা সম্পর্কে তথ্য থাকে। আপনি Google ট্যাগ ম্যানেজারে যে সমস্ত তথ্য পাঠাতে চান সেগুলি এই বস্তুগুলিতে থাকে৷
ট্যাগ ট্রিগার করতে ডেটা স্তরটিও ব্যবহার করা যেতে পারে।
// Contents of the data layer
window.dataLayer = [{
'pageCategory': 'signup',
'visitorType': 'high-value'
}];
// Pushing a variable to the data layer
window.dataLayer.push({'variable_name': 'variable_value'});
// Pushing an event to the data layer
window.dataLayer.push({'event': 'event_name'});
যদিও Google ট্যাগ ম্যানেজার ডেটা স্তর ছাড়াই ব্যবহার করা যেতে পারে, এটি দৃঢ়ভাবে সুপারিশ করা হয়। ডেটা স্তরটি এমন ডেটা একত্রিত করে যা তৃতীয় পক্ষের স্ক্রিপ্ট দ্বারা একক জায়গায় অ্যাক্সেস করা যায়, এইভাবে এটির ব্যবহারে আরও ভাল দৃশ্যমানতা প্রদান করে। অন্যান্য জিনিসের মধ্যে, এটি অপ্রয়োজনীয় পরিবর্তনশীল গণনা এবং স্ক্রিপ্ট সম্পাদন কমাতে সাহায্য করতে পারে।
একটি ডেটা স্তর ব্যবহার করে, আপনি সম্পূর্ণ জাভাস্ক্রিপ্ট ভেরিয়েবল বা DOM অ্যাক্সেস দেওয়ার পরিবর্তে ট্যাগ দ্বারা কোন ডেটা অ্যাক্সেস করা হয় তা নিয়ন্ত্রণ করতে পারেন।
ডেটা স্তরের কার্যকারিতা সুবিধাগুলি স্বজ্ঞাত নাও হতে পারে, এই কারণে যে ডেটা স্তর আপডেট করার ফলে Google ট্যাগ ম্যানেজার সমস্ত কন্টেইনার ভেরিয়েবলের পুনর্মূল্যায়ন করে এবং সম্ভাব্যভাবে ট্যাগগুলিকে ট্রিগার করে, যা জাভাস্ক্রিপ্ট এক্সিকিউশনকে অন্তর্ভুক্ত করে। যদিও ডেটা স্তরের অপব্যবহার করা সম্ভব, সাধারণভাবে বলতে গেলে, যদি ডেটা স্তরটি কর্মক্ষমতা সংক্রান্ত সমস্যার উৎস বলে মনে হয়, তবে ধারকটিরই কার্যক্ষমতার সমস্যা থাকতে পারে। ডেটা স্তর এই সমস্যাগুলিকে আরও স্পষ্ট করে তোলে।
সদৃশ এবং অব্যবহৃত ট্যাগগুলি সরান
ডুপ্লিকেট ট্যাগগুলি ঘটতে পারে যখন একটি ট্যাগ একটি পৃষ্ঠার এইচটিএমএল মার্কআপে অন্তর্ভুক্ত করা হয় এবং একটি ট্যাগ ম্যানেজারের মাধ্যমে ইনজেক্ট করা হয়৷
অব্যবহৃত ট্যাগ একটি ট্রিগার ব্যতিক্রম ব্যবহারের মাধ্যমে অবরুদ্ধ করার পরিবর্তে বিরতি বা সরানো উচিত। একটি ট্যাগ বিরতি বা অপসারণ কন্টেইনার থেকে কোড সরিয়ে দেয়; ব্লক করা হয় না।
যখন অব্যবহৃত ট্যাগগুলি সরানো হয়, তখন ট্রিগার এবং ভেরিয়েবলগুলিকেও মুছে ফেলা যায় কিনা তা নির্ধারণ করতে পর্যালোচনা করুন৷
বিরাম দেওয়া ট্যাগ কন্টেইনারের আকারকে প্রভাবিত করে, তবে, ট্যাগগুলি সক্রিয় থাকার সময় থেকে মোট পেলোড ছোট।
অনুমতি এবং অস্বীকার তালিকা ব্যবহার করুন
একটি পৃষ্ঠায় অনুমোদিত ট্যাগ, ট্রিগার এবং ভেরিয়েবলগুলিতে অত্যন্ত দানাদার সীমাবদ্ধতা কনফিগার করার জন্য তালিকাগুলিকে অনুমতি দিন এবং অস্বীকার করুন । পারফরম্যান্সের সর্বোত্তম অনুশীলন এবং অন্যান্য নীতিগুলি কার্যকর করতে এটি ব্যবহার করা যেতে পারে।
অনুমতি এবং অস্বীকার তালিকাগুলি ডেটা স্তরের মাধ্যমে কনফিগার করা হয়।
window.dataLayer = [{
'gtm.allowlist': ['<id>', '<id>', ...],
'gtm.blocklist': ['customScripts']
}];
উদাহরণস্বরূপ, আপনি কাস্টম HTML ট্যাগ, জাভাস্ক্রিপ্ট ভেরিয়েবল বা সরাসরি DOM অ্যাক্সেসের ব্যবহার প্রতিরোধ করতে পারেন। এর মানে হবে শুধুমাত্র পিক্সেল এবং পূর্বনির্ধারিত ট্যাগ ব্যবহার করা যেতে পারে, ডেটা লেয়ার থেকে ডেটা সহ। যদিও এটি সীমাবদ্ধ, এটি আরও কার্যকরী এবং সুরক্ষিত ট্যাগ ম্যানেজার বাস্তবায়নে পরিণত হতে পারে।
সার্ভার-সাইড ট্যাগিং ব্যবহার করার কথা বিবেচনা করুন
সার্ভার-সাইড ট্যাগিং-এ একটি সুইচ বিবেচনা করা মূল্যবান, বিশেষ করে বড় সাইটগুলির জন্য যারা তাদের ডেটার উপর আরও নিয়ন্ত্রণ চায়৷ সার্ভার-সাইড ট্যাগিং ক্লায়েন্ট থেকে বিক্রেতা কোড সরিয়ে দেয় এবং এটির সাথে, ক্লায়েন্ট থেকে সার্ভারে প্রক্রিয়াকরণ অফলোড করে।
উদাহরণ স্বরূপ, ক্লায়েন্ট-সাইড ট্যাগিং ব্যবহার করার সময়, একাধিক অ্যানালিটিক্স অ্যাকাউন্টে ডেটা পাঠানোর ফলে ক্লায়েন্ট প্রতিটি শেষ পয়েন্টের জন্য আলাদা অনুরোধ শুরু করে। সার্ভার-সাইড ট্যাগিংয়ের সাথে, ক্লায়েন্ট সার্ভার-সাইড কন্টেইনারে একটি একক অনুরোধ করে এবং সেখান থেকে, এই ডেটা বিভিন্ন বিশ্লেষণ অ্যাকাউন্টে ফরোয়ার্ড করা হয়।
মনে রাখবেন যে সার্ভার-সাইড ট্যাগিং শুধুমাত্র কিছু ট্যাগের সাথে কাজ করে। ট্যাগ সামঞ্জস্য বিক্রেতার উপর নির্ভর করে পরিবর্তিত হয়।
আরও তথ্যের জন্য, সার্ভার-সাইড ট্যাগিংয়ের একটি ভূমিকা দেখুন।
পাত্রে
ট্যাগ ম্যানেজাররা সাধারণত তাদের সেট আপের মধ্যে একাধিক দৃষ্টান্তের অনুমতি দেয়, প্রায়ই কন্টেইনার হিসাবে উল্লেখ করা হয়। একটি ট্যাগ ম্যানেজার অ্যাকাউন্টের মধ্যে একাধিক পাত্র নিয়ন্ত্রণ করা যেতে পারে।
প্রতি পৃষ্ঠায় শুধুমাত্র একটি ধারক ব্যবহার করুন
একক পৃষ্ঠায় একাধিক কন্টেইনার উল্লেখযোগ্য কর্মক্ষমতা সমস্যা তৈরি করতে পারে, কারণ এটি অতিরিক্ত ওভারহেড এবং স্ক্রিপ্ট এক্সিকিউশন প্রবর্তন করে। অন্ততপক্ষে, এটি মূল ট্যাগ কোডের নকল করে যা, যেহেতু এটি কন্টেইনারের জাভাস্ক্রিপ্টের অংশ হিসাবে বিতরণ করা হয়েছে, কন্টেইনারগুলির মধ্যে পুনরায় ব্যবহার করা যাবে না।
একাধিক পাত্রে কার্যকরভাবে ব্যবহার করা বিরল। যাইহোক, এমন কিছু উদাহরণ রয়েছে যখন এটি কাজ করতে পারে, যদি ভালভাবে নিয়ন্ত্রণ করা হয়। যেমন:
- একটি বড় পাত্রের পরিবর্তে একটি হালকা "আর্লি লোড" কন্টেইনার এবং একটি ভারী "পরে লোড" কন্টেইনার সহ।
- কম প্রযুক্তিগত ব্যবহারকারীদের জন্য একটি সীমাবদ্ধ কন্টেইনার ব্যবহার করা এবং আরও জটিল ট্যাগের জন্য কম সীমাবদ্ধ, কিন্তু আরও শক্তভাবে নিয়ন্ত্রিত কন্টেইনার।
যদি আপনাকে প্রতি পৃষ্ঠায় একাধিক কন্টেইনার ব্যবহার করতে হয়, একাধিক কন্টেইনার সেট আপ করার জন্য Google ট্যাগ ম্যানেজার নির্দেশিকা অনুসরণ করুন ।
প্রয়োজনে আলাদা পাত্র ব্যবহার করুন
আপনি যদি একাধিক বৈশিষ্ট্যের জন্য একটি ট্যাগ ম্যানেজার ব্যবহার করেন, যেমন একটি ওয়েব অ্যাপ এবং একটি মোবাইল অ্যাপ, আপনি যে কন্টেইনারগুলি ব্যবহার করেন তা আপনার কর্মপ্রবাহের উত্পাদনশীলতাকে সাহায্য করতে পারে বা ক্ষতি করতে পারে৷ এটি কর্মক্ষমতা প্রভাবিত করতে পারে।
একটি একক ধারক কার্যকরভাবে একাধিক সাইট জুড়ে ব্যবহার করা যেতে পারে যদি সাইটগুলি ব্যবহার এবং গঠনে একই রকম হয়। উদাহরণস্বরূপ, যদিও একটি ব্র্যান্ডের মোবাইল এবং ওয়েব অ্যাপগুলি একই রকম ফাংশন পরিবেশন করতে পারে, তবে সম্ভবত অ্যাপগুলি আলাদাভাবে গঠন করা হয়েছে এবং তাই আলাদা কন্টেইনারের মাধ্যমে আরও কার্যকরভাবে পরিচালনা করা যেতে পারে।
একটি একক ধারককে খুব বিস্তৃতভাবে পুনঃব্যবহার করলে ট্যাগ এবং ট্রিগারগুলি পরিচালনা করতে জটিল যুক্তিকে বাধ্য করে কন্টেইনারের জটিলতা এবং আকার বৃদ্ধি করতে পারে।
পাত্রের আকারের দিকে নজর রাখুন
একটি পাত্রের আকার তার ট্যাগ, ট্রিগার এবং ভেরিয়েবল দ্বারা নির্ধারিত হয়। যদিও একটি ছোট ধারক এখনও পৃষ্ঠার কার্যকারিতাকে নেতিবাচকভাবে প্রভাবিত করতে পারে, একটি বড় ধারক প্রায় অবশ্যই করবে।
আপনার ট্যাগ ব্যবহার অপ্টিমাইজ করার সময় কন্টেইনারের আকার সবচেয়ে গুরুত্বপূর্ণ মেট্রিক হওয়া উচিত নয়। যাইহোক, একটি বড় পাত্রের আকার প্রায়শই একটি সতর্কতা সংকেত যে একটি ধারক ভালভাবে রক্ষণাবেক্ষণ করা হয় না এবং সম্ভবত অপব্যবহার করা হয়।
Google ট্যাগ ম্যানেজার কন্টেইনারের আকার 300 KB-এ সীমাবদ্ধ করে এবং কন্টেইনারের আকার সীমার 70% এ পৌঁছানোর পরে সতর্ক করে।
বেশিরভাগ সাইটের লক্ষ্য হওয়া উচিত তাদের পাত্রে সীমাবদ্ধতার চেয়ে ছোট রাখা। তুলনা করার জন্য, মিডিয়ান সাইটের ধারক প্রায় 50 KB। নিজেই, Google ট্যাগ ম্যানেজার লাইব্রেরি প্রায় 33 KB সংকুচিত।
আপনার ধারক সংস্করণের নাম দিন
একটি কন্টেইনার সংস্করণ হল একটি নির্দিষ্ট সময়ে একটি কন্টেইনারের বিষয়বস্তুর একটি স্ন্যাপশট। একটি অর্থপূর্ণ নাম ব্যবহার করা এবং এর মধ্যে অর্থপূর্ণ পরিবর্তনগুলির একটি সংক্ষিপ্ত বিবরণ অন্তর্ভুক্ত করা ভবিষ্যতের কার্যক্ষমতা সমস্যাগুলিকে সহজতর করার জন্য একটি দীর্ঘ পথ যেতে পারে।
ট্যাগ ওয়ার্কফ্লো
আপনার ট্যাগগুলির পরিবর্তনগুলি পরিচালনা করা গুরুত্বপূর্ণ যাতে সেগুলি পৃষ্ঠার কর্মক্ষমতাতে নেতিবাচক প্রভাব না ফেলে৷
স্থাপন করার আগে পরীক্ষা করুন
সমস্যা, কর্মক্ষমতা এবং অন্যথায়, পাঠানোর আগে মোতায়েন করার আগে আপনার ট্যাগ পরীক্ষা করুন।
ট্যাগ পরীক্ষা করার সময় যে বিষয়গুলি বিবেচনা করতে হবে তার মধ্যে রয়েছে:
- ট্যাগ সঠিকভাবে কাজ করছে?
- ট্যাগ কি কোনো লেআউট পরিবর্তনের কারণ?
- ট্যাগ কি কোনো সম্পদ লোড করে? এই সম্পদ কত বড়?
- ট্যাগ কি একটি দীর্ঘ-চলমান স্ক্রিপ্ট ট্রিগার করে?
প্রিভিউ মোড
পূর্বরূপ মোড আপনাকে প্রথমে জনসাধারণের কাছে স্থাপন না করেই আপনার প্রকৃত সাইটে ট্যাগ পরিবর্তনগুলি পরীক্ষা করতে দেয়৷ পূর্বরূপ মোডে একটি ডিবাগিং কনসোল রয়েছে যা ট্যাগ সম্পর্কে তথ্য প্রদান করে।
ডিবাগিং কনসোলে তথ্য প্রকাশের জন্য প্রয়োজনীয় অতিরিক্ত ওভারহেডের কারণে প্রিভিউ মোডে চালানোর সময় Google ট্যাগ ম্যানেজারের কার্য সম্পাদনের সময় ভিন্ন (সামান্য ধীর) হয়। সুতরাং, প্রিভিউ মোডে সংগৃহীত ওয়েব ভাইটাল পরিমাপ উৎপাদনে সংগৃহীতদের সাথে তুলনা করার পরামর্শ দেওয়া হয় না। যাইহোক, এই অসঙ্গতিটি ট্যাগগুলির কার্যকর আচরণকে প্রভাবিত করবে না।
স্বতন্ত্র পরীক্ষা
ট্যাগ পরীক্ষা করার একটি বিকল্প পদ্ধতি হল একটি খালি পৃষ্ঠা সেট আপ করা যাতে একটি একক ট্যাগ সহ একটি ধারক থাকে—যে ট্যাগটি আপনি পরীক্ষা করছেন। এই টেস্টিং সেটআপটি কম বাস্তবসম্মত এবং কিছু সমস্যা ধরবে না (উদাহরণস্বরূপ, একটি ট্যাগ লেআউট পরিবর্তনের কারণ কিনা)—তবে এটি স্ক্রিপ্ট এক্সিকিউশনের মতো জিনিসগুলিতে ট্যাগের প্রভাবকে আলাদা করা এবং পরিমাপ করা সহজ করে তুলতে পারে। তৃতীয় পক্ষের কোডের কর্মক্ষমতা উন্নত করতে টেলিগ্রাফ কীভাবে এই বিচ্ছিন্নতা পদ্ধতি ব্যবহার করে তা দেখুন।
ট্যাগ কর্মক্ষমতা নিরীক্ষণ
Google ট্যাগ ম্যানেজার মনিটরিং এপিআই একটি নির্দিষ্ট ট্যাগ কার্যকর করার সময় সম্পর্কে তথ্য সংগ্রহ করতে ব্যবহার করা যেতে পারে। এই তথ্য আপনার পছন্দের একটি শেষ পয়েন্ট রিপোর্ট করা হয়.
আরও তথ্যের জন্য, দেখুন কিভাবে একটি Google ট্যাগ ম্যানেজার মনিটর তৈরি করবেন ।
ধারক পরিবর্তনের জন্য অনুমোদন প্রয়োজন
প্রথম পক্ষের কোড সাধারণত স্থাপনার আগে পর্যালোচনা এবং পরীক্ষার মধ্য দিয়ে যায়। আপনার ট্যাগ একই আচরণ.
দ্বি-পদক্ষেপ যাচাইকরণ যোগ করা, যার জন্য কন্টেইনার পরিবর্তনের জন্য প্রশাসকের অনুমোদন প্রয়োজন, এটি করার একটি উপায়। বিকল্পভাবে, আপনি যদি দ্বি-পদক্ষেপ যাচাইকরণের প্রয়োজন না করতে চান তবে পরিবর্তনগুলির উপর নজর রাখতে চান, আপনি আপনার পছন্দের কন্টেইনার ইভেন্টগুলি সম্পর্কে ইমেল সতর্কতা পেতে কন্টেইনার বিজ্ঞপ্তিগুলি সেট আপ করতে পারেন৷
পর্যায়ক্রমে ট্যাগ ব্যবহার অডিট
ট্যাগগুলির সাথে কাজ করার চ্যালেঞ্জগুলির মধ্যে একটি হল যে তারা সময়ের সাথে সাথে জমা হতে থাকে: ট্যাগগুলি যোগ করা হয় কিন্তু খুব কমই সরানো হয়। পর্যায়ক্রমে ট্যাগ অডিটিং এই প্রবণতা বিপরীত একটি উপায়. এটি করার জন্য আদর্শ ফ্রিকোয়েন্সি নির্ভর করে আপনার সাইটের ট্যাগগুলি কত ঘন ঘন আপডেট করা হয় তার উপর।
প্রতিটি ট্যাগ লেবেল করা যাতে মালিক সুস্পষ্ট হয় সেই ট্যাগের জন্য কে প্রতিক্রিয়াশীল তা সহজে সনাক্ত করার অনুমতি দেয় এবং এটি এখনও প্রয়োজন কিনা তা বলতে পারে।
ট্যাগ অডিট করার সময়, ট্রিগার এবং ভেরিয়েবলগুলি পরিষ্কার করতে ভুলবেন না। তারা প্রায়ই কর্মক্ষমতা সমস্যার কারণ হতে পারে, এছাড়াও.
আরও তথ্যের জন্য, তৃতীয় পক্ষের স্ক্রিপ্ট নিয়ন্ত্রণে রাখা দেখুন।
,প্রকাশিত: জুলাই 29, 2021
ট্যাগ হল থার্ড-পার্টি কোডের স্নিপেট যা একটি সাইটে ঢোকানো হয়, সাধারণত ট্যাগ ম্যানেজার দিয়ে। ট্যাগগুলি সাধারণত মার্কেটিং এবং বিশ্লেষণের জন্য ব্যবহৃত হয়।
ট্যাগ এবং ট্যাগ পরিচালকদের কর্মক্ষমতা প্রভাব বিভিন্ন সাইট জুড়ে ব্যাপকভাবে পরিবর্তিত হয়। ট্যাগ ম্যানেজারদের একটি খামের সাথে তুলনা করা যেতে পারে: ট্যাগ ম্যানেজার একটি পাত্র সরবরাহ করে, কিন্তু আপনি এটি কী দিয়ে পূরণ করবেন এবং আপনি কীভাবে এটি ব্যবহার করবেন তা বেশিরভাগই আপনার উপর নির্ভর করে।
এখানে, আমরা কর্মক্ষমতা এবং মূল ওয়েব ভাইটালগুলির জন্য ট্যাগ এবং ট্যাগ পরিচালকদের অপ্টিমাইজ করার কৌশল নিয়ে আলোচনা করি। যদিও এই নথিটি Google ট্যাগ ম্যানেজারকে উল্লেখ করে, আলোচিত অনেক ধারণা অন্যান্য ট্যাগ পরিচালকদের ক্ষেত্রে প্রযোজ্য।
কোর ওয়েব ভাইটালসের উপর প্রভাব
ট্যাগ ম্যানেজাররা প্রায়ই আপনার পৃষ্ঠাটি দ্রুত লোড করতে এবং এটিকে প্রতিক্রিয়াশীল রাখতে প্রয়োজনীয় সংস্থানগুলি ব্যবহার করে আপনার মূল ওয়েব ভাইটালগুলিকে পরোক্ষভাবে প্রভাবিত করতে পারে। ব্যান্ডউইথ আপনার সাইটের জন্য ট্যাগ ম্যানেজার জাভাস্ক্রিপ্ট ডাউনলোড করতে খরচ করা যেতে পারে, বা এর পরবর্তী কলগুলি। মূল থ্রেডে CPU সময় ট্যাগ ম্যানেজার এবং ট্যাগের মধ্যে থাকা জাভাস্ক্রিপ্ট মূল্যায়ন এবং কার্যকর করার জন্য ব্যয় করা যেতে পারে।
সবচেয়ে বড় কন্টেন্টফুল পেইন্ট (LCP) গুরুত্বপূর্ণ পৃষ্ঠা লোডের সময় ব্যান্ডউইথ বিতর্কের জন্য ঝুঁকিপূর্ণ। উপরন্তু, প্রধান থ্রেড ব্লক করা LCP রেন্ডারের সময়কে বিলম্বিত করতে পারে।
ক্রমবর্ধমান লেআউট শিফট (CLS) প্রভাবিত হতে পারে, হয় প্রথম রেন্ডারের আগে গুরুত্বপূর্ণ সংস্থান লোড করতে দেরি করে, অথবা ট্যাগ ম্যানেজারদের দ্বারা পৃষ্ঠায় সামগ্রী প্রবেশ করানো হয়৷
নেক্সট পেইন্টের সাথে ইন্টারঅ্যাকশন (আইএনপি) মূল থ্রেডে সিপিইউ বিতর্কের জন্য সংবেদনশীল, এবং আমরা ট্যাগ ম্যানেজার এবং দরিদ্র INP স্কোরের মধ্যে একটি সম্পর্ক দেখেছি।
সঠিক ট্যাগ টাইপ নির্বাচন করুন
কর্মক্ষমতা উপর ট্যাগ প্রভাব ট্যাগ ধরনের দ্বারা পরিবর্তিত হয়. সাধারণভাবে বলতে গেলে, ইমেজ ট্যাগগুলি ("পিক্সেল") সবচেয়ে কার্যকরী, তার পরে কাস্টম টেমপ্লেট এবং সবশেষে, কাস্টম এইচটিএমএল ট্যাগ৷ বিক্রেতা ট্যাগগুলি তাদের অনুমতি দেওয়া কার্যকারিতার উপর নির্ভর করে পরিবর্তিত হয়।
মনে রাখবেন যে আপনি কীভাবে একটি ট্যাগ ব্যবহার করেন তা এর কার্যকারিতার প্রভাবকে ব্যাপকভাবে প্রভাবিত করে। "পিক্সেল" অনেক বেশি পারফরম্যান্স করে কারণ এই ট্যাগ টাইপের প্রকৃতি তাদের কীভাবে ব্যবহার করা যেতে পারে তার উপর কঠোর বিধিনিষেধ আরোপ করে; কাস্টম এইচটিএমএল ট্যাগগুলি সর্বদা কর্মক্ষমতার জন্য খারাপ নয়, তবে তারা ব্যবহারকারীদের যে স্বাধীনতা প্রদান করে তার কারণে, তাদের কার্যক্ষমতার জন্য খারাপ এমনভাবে অপব্যবহার করা সহজ হতে পারে।
ট্যাগ সম্পর্কে চিন্তা করার সময়, স্কেলটি মনে রাখবেন: যে কোনও একক ট্যাগের কার্যকারিতা প্রভাব নগণ্য হতে পারে—কিন্তু একই পৃষ্ঠায় দশ বা শত শত ট্যাগ ব্যবহার করা হলে তা তাৎপর্যপূর্ণ হতে পারে।
সব স্ক্রিপ্ট ট্যাগ ম্যানেজার দিয়ে লোড করা উচিত নয়
ট্যাগ ম্যানেজার সাধারণত রিসোর্স লোড করার সর্বোত্তম উপায় নয় যা ব্যবহারকারীর অভিজ্ঞতার অবিলম্বে চাক্ষুষ বা কার্যকরী দিকগুলি প্রয়োগ করে, যেমন কুকি নোটিশ, হিরো ছবি বা সাইটের বৈশিষ্ট্যগুলি। এই সংস্থানগুলি লোড করার জন্য একটি ট্যাগ ম্যানেজার ব্যবহার করা সাধারণত তাদের বিতরণে বিলম্ব করে। এটি ব্যবহারকারীর অভিজ্ঞতার জন্য খারাপ এবং এটি LCP এবং CLS-এর মতো মেট্রিক্সও বাড়াতে পারে।
উপরন্তু, কিছু ব্যবহারকারী ট্যাগ ম্যানেজার ব্লক. UX বৈশিষ্ট্যগুলি বাস্তবায়নের জন্য একটি ট্যাগ ম্যানেজার ব্যবহার করার ফলে আপনার কিছু ব্যবহারকারীর জন্য একটি ভাঙা ওয়েবসাইট হতে পারে৷
কাস্টম এইচটিএমএল ট্যাগের সাথে সতর্ক থাকুন
কাস্টম এইচটিএমএল ট্যাগগুলি বহু বছর ধরে রয়েছে এবং বেশিরভাগ সাইটে ব্যাপকভাবে ব্যবহৃত হয়৷ কাস্টম এইচটিএমএল ট্যাগ আপনাকে কিছু বিধিনিষেধ সহ আপনার নিজস্ব কোড প্রবেশ করার অনুমতি দেয় কারণ নাম থাকা সত্ত্বেও, এই ট্যাগের প্রধান ব্যবহার হল একটি পৃষ্ঠায় কাস্টম <script>
উপাদান যোগ করা।
কাস্টম HTML ট্যাগগুলি বিভিন্ন উপায়ে ব্যবহার করা যেতে পারে এবং তাদের কর্মক্ষমতা প্রভাব উল্লেখযোগ্যভাবে পরিবর্তিত হয়। আপনার সাইটের পারফরম্যান্স পরিমাপ করার সময়, সচেতন হোন যে বেশিরভাগ টুলগুলি ট্যাগ ম্যানেজারকে ইঞ্জেকশন দেওয়ার জন্য একটি কাস্টম এইচটিএমএল ট্যাগের কার্যক্ষমতার প্রভাবকে দায়ী করে — ট্যাগটির পরিবর্তে।
কাস্টম HTML ট্যাগ পার্শ্ববর্তী পৃষ্ঠায় একটি উপাদান সন্নিবেশ করতে পারে। পৃষ্ঠায় উপাদান ঢোকানোর কাজটি পারফরম্যান্স সমস্যার একটি উৎস হতে পারে এবং কিছু ক্ষেত্রে লেআউট পরিবর্তনের কারণও হতে পারে।
- বেশিরভাগ পরিস্থিতিতে, যদি একটি উপাদান পৃষ্ঠায় ঢোকানো হয়, ব্রাউজারটিকে অবশ্যই পৃষ্ঠায় প্রতিটি আইটেমের আকার এবং অবস্থান পুনঃগণনা করতে হবে। এই প্রক্রিয়াটি লেআউট হিসাবে পরিচিত। একটি একক লেআউটের কর্মক্ষমতা প্রভাব ন্যূনতম, কিন্তু যখন এটি অত্যধিক ঘটে তখন এটি কর্মক্ষমতা সমস্যার একটি উৎস হয়ে উঠতে পারে। এই ঘটনার প্রভাব নিম্ন-প্রান্তের ডিভাইস এবং উচ্চ সংখ্যক DOM উপাদান সহ পৃষ্ঠাগুলিতে বেশি।
- আশেপাশের এলাকা ইতিমধ্যে রেন্ডার করার পরে যদি একটি দৃশ্যমান পৃষ্ঠা উপাদান DOM-এ ঢোকানো হয়, তাহলে এটি একটি লেআউট পরিবর্তনের কারণ হতে পারে। এই ঘটনাটি ট্যাগ ম্যানেজারদের জন্য অনন্য নয়-তবে, কারণ ট্যাগগুলি সাধারণত পৃষ্ঠার অন্যান্য অংশের তুলনায় পরে লোড হয়, তাই তাদের জন্য আশেপাশের পৃষ্ঠাটি ইতিমধ্যে রেন্ডার হওয়ার পরে DOM-এ ঢোকানো সাধারণ।
কাস্টম টেমপ্লেট ব্যবহার করুন
কাস্টম টেমপ্লেটগুলি কাস্টম এইচটিএমএল ট্যাগের মতো কিছু ক্রিয়াকলাপকে সমর্থন করে তবে জাভাস্ক্রিপ্টের একটি স্যান্ডবক্সড সংস্করণের উপর নির্মিত যা স্ক্রিপ্ট ইনজেকশন এবং পিক্সেল ইনজেকশনের মতো সাধারণ ব্যবহারের ক্ষেত্রে API প্রদান করে। নামটি বোঝায়, তারা একটি টেমপ্লেট তৈরি করার অনুমতি দেয়, এমন একজন শক্তি ব্যবহারকারীর দ্বারা, যারা কর্মক্ষমতা মাথায় রেখে এটি তৈরি করতে পারে। কম প্রযুক্তিগত ব্যবহারকারীরা তারপর টেমপ্লেট ব্যবহার করতে পারেন। এটি প্রায়ই সম্পূর্ণ কাস্টম HTML অ্যাক্সেস প্রদানের চেয়ে নিরাপদ।
কাস্টম টেমপ্লেটগুলিতে আরোপিত বৃহত্তর বিধিনিষেধের কারণে, এই ট্যাগগুলির কার্যকারিতা বা নিরাপত্তা সমস্যাগুলি প্রদর্শন করার সম্ভাবনা অনেক কম। এই একই কারণে, কাস্টম টেমপ্লেটগুলি সমস্ত ব্যবহারের ক্ষেত্রে কাজ করে না।
সঠিকভাবে স্ক্রিপ্ট ইনজেক্ট করুন
একটি স্ক্রিপ্ট ইনজেক্ট করার জন্য একটি ট্যাগ ম্যানেজার ব্যবহার করা একটি খুব সাধারণ ব্যবহারের ক্ষেত্রে। এটি করার প্রস্তাবিত উপায় হল একটি কাস্টম টেমপ্লেট এবং injectScript
API ব্যবহার করা।
একটি বিদ্যমান কাস্টম HTML ট্যাগ রূপান্তর করতে injectScript API ব্যবহার করার তথ্যের জন্য, একটি বিদ্যমান ট্যাগ রূপান্তর দেখুন।
আপনি যদি একটি কাস্টম HTML ট্যাগ ব্যবহার করতে চান, মনে রাখবেন:
- লাইব্রেরি এবং বড় তৃতীয় পক্ষের স্ক্রিপ্টগুলিকে একটি স্ক্রিপ্ট ট্যাগ দিয়ে লোড করা উচিত (উদাহরণস্বরূপ,
<script src="external-scripts.js">
) যা একটি বহিরাগত ফাইল ডাউনলোড করে, স্ক্রিপ্টের বিষয়বস্তু সরাসরি ট্যাগে কপি-পেস্ট করার পরিবর্তে। যদিও<script>
ট্যাগের ব্যবহার ভুলে যাওয়া স্ক্রিপ্টের বিষয়বস্তু ডাউনলোড করার জন্য একটি পৃথক রাউন্ড-ট্রিপ বাদ দেয়, এই অনুশীলনটি কন্টেইনারের আকার বাড়ায় এবং ব্রাউজার দ্বারা স্ক্রিপ্টটিকে আলাদাভাবে ক্যাশে করা থেকে বাধা দেয়। - অনেক বিক্রেতা তাদের
<script>
ট্যাগ<head>
এর উপরে রাখার পরামর্শ দেন। যাইহোক, ট্যাগ ম্যানেজার দিয়ে লোড করা স্ক্রিপ্টগুলির জন্য, এটি প্রায়শই অপ্রয়োজনীয়। বেশিরভাগ পরিস্থিতিতে, ট্যাগ ম্যানেজার কার্যকর করার সময় ব্রাউজার ইতিমধ্যেই<head>
পার্সিং শেষ করেছে।
পিক্সেল ব্যবহার করুন
কখনও কখনও, তৃতীয় পক্ষের স্ক্রিপ্টগুলিকে চিত্র বা আইফ্রেম পিক্সেল দিয়ে প্রতিস্থাপন করা যেতে পারে। তাদের স্ক্রিপ্ট-ভিত্তিক প্রতিরূপের তুলনায়, পিক্সেলগুলি কম কার্যকারিতা সমর্থন করতে পারে, তাই প্রায়শই কম-পছন্দের বাস্তবায়ন হিসাবে দেখা হয়। যাইহোক, যখন ট্যাগ ম্যানেজারগুলির ভিতরে ব্যবহার করা হয়, তখন পিক্সেলগুলি আরও গতিশীল হতে পারে কারণ তারা ট্রিগারগুলিতে ফায়ার করতে পারে এবং বিভিন্ন ভেরিয়েবল পাস করতে পারে।
পিক্সেল হল সবচেয়ে পারফরম্যান্স এবং সুরক্ষিত ধরনের ট্যাগ কারণ এটি ফায়ার করার পরে কোন জাভাস্ক্রিপ্ট এক্সিকিউশন নেই। পিক্সেলগুলির একটি খুব ছোট সংস্থান আকার (1 KB-এর কম) এবং লেআউট পরিবর্তনের কারণ হয় না৷
পিক্সেলের জন্য তাদের সমর্থন সম্পর্কে আরও তথ্যের জন্য আপনার তৃতীয়-পক্ষ প্রদানকারীর সাথে যোগাযোগ করুন। উপরন্তু, আপনি একটি <noscript>
ট্যাগের জন্য তাদের কোড পরিদর্শন করার চেষ্টা করতে পারেন। যদি কোনো বিক্রেতা পিক্সেল সমর্থন করে, তারা প্রায়ই <noscript>
ট্যাগের মধ্যে পিক্সেল অন্তর্ভুক্ত করে।
পিক্সেলের বিকল্প
পিক্সেলগুলি মূলত জনপ্রিয় হয়ে ওঠে কারণ এক সময়ে সার্ভারের প্রতিক্রিয়া প্রাসঙ্গিক নয় এমন পরিস্থিতিতে একটি HTTP অনুরোধ করার সবচেয়ে সস্তা এবং সবচেয়ে নির্ভরযোগ্য উপায়গুলির মধ্যে একটি ছিল (উদাহরণস্বরূপ, বিশ্লেষণ প্রদানকারীদের কাছে ডেটা পাঠানোর সময়)। navigator.sendBeacon()
এবং fetch() keepalive
API-গুলি একই ব্যবহারের ক্ষেত্রে সমাধান করার জন্য ডিজাইন করা হয়েছে কিন্তু পিক্সেলের তুলনায় যুক্তিযুক্তভাবে বেশি নির্ভরযোগ্য।
পিক্সেল ব্যবহার চালিয়ে যাওয়ার ক্ষেত্রে কোনও ভুল নেই - এগুলি ভালভাবে সমর্থিত এবং ন্যূনতম পারফরম্যান্সের প্রভাব রয়েছে। তবে, আপনি যদি নিজের বীকনগুলি তৈরি করছেন তবে এই এপিআইগুলির মধ্যে একটি ব্যবহার করে বিবেচনা করা উচিত।
sendBeacon()
navigator.sendBeacon()
এপিআই সার্ভারের প্রতিক্রিয়া বিবেচ্য নয় এমন পরিস্থিতিতে ওয়েব সার্ভারগুলিতে অল্প পরিমাণে ডেটা প্রেরণের জন্য ডিজাইন করা হয়েছে।
const url = "https://example.com/analytics";
const data = JSON.stringify({
event: "checkout",
time: performance.now()
});
navigator.sendBeacon(url, data);
sendBeacon()
একটি সীমিত এপিআই রয়েছে: এটি কেবল পোস্টের অনুরোধগুলি তৈরি করতে সমর্থন করে এবং কাস্টম শিরোনাম সেটিং সেটিং সমর্থন করে না। এটি সমস্ত আধুনিক ব্রাউজার দ্বারা সমর্থিত ।
এপিআই keepalive
আনুন
keepalive
এমন একটি পতাকা যা ফেচ এপিআইকে ইভেন্ট রিপোর্টিং এবং বিশ্লেষণের মতো নন-ব্লকিং অনুরোধগুলি তৈরি করতে ব্যবহার করতে দেয়। এটি রক্ষণশীলকে অন্তর্ভুক্ত করে ব্যবহার করা হয়: fetch()
এ পাস হওয়া পরামিতিগুলিতে keepalive: true
।
const url = "https://example.com/analytics";
const data = JSON.stringify({
event: "checkout",
time: performance.now()
});
fetch(url, {
method: 'POST',
body: data,
keepalive: true
});
যদি fetch() keepalive
এবং sendBeacon()
খুব অনুরূপ মনে হয় তবে এটি কারণ তারা। প্রকৃতপক্ষে, ক্রোমিয়াম ব্রাউজারগুলিতে, sendBeacon()
এখন fetch() keepalive
উপর নির্মিত।
fetch() keepalive
এবং sendBeacon()
এর মধ্যে নির্বাচন করার সময়, আপনার প্রয়োজনীয় বৈশিষ্ট্যগুলি এবং ব্রাউজার সমর্থন বিবেচনা করা গুরুত্বপূর্ণ। আনতে () এপিআই উল্লেখযোগ্যভাবে আরও নমনীয়; যাইহোক, keepalive
sendBeacon()
চেয়ে কম ব্রাউজার সমর্থন রয়েছে।
ট্যাগগুলি কী করে তা বুঝতে
ট্যাগগুলি প্রায়শই তৃতীয় পক্ষের বিক্রেতার দ্বারা প্রদত্ত গাইডেন্স অনুসরণ করে তৈরি করা হয়। যদি কোনও বিক্রেতার কোড কী তা স্পষ্ট না হয় তবে জানেন এমন কাউকে জিজ্ঞাসা করুন। দ্বিতীয় মতামত পাওয়া কোনও ট্যাগের কার্যকারিতা বা সুরক্ষা সমস্যা তৈরি করার সম্ভাবনা থাকে কিনা তা সনাক্ত করতে সহায়তা করতে পারে।
আমরা ট্যাগ ম্যানেজারের মালিকের সাথে লেবেলিং ট্যাগগুলির প্রস্তাব দিই। কে কোনও ট্যাগের মালিক তা ভুলে যাওয়া সহজ, এটি কোনও কিছু ভেঙে যাওয়ার ক্ষেত্রে অপসারণের ভয়ে নিয়ে যায়!
ট্রিগার
একটি উচ্চ-স্তরে, অনুকূলিতকরণ ট্যাগ ট্রিগারগুলি সাধারণত প্রয়োজনের চেয়ে বেশি ট্রিগার ট্যাগ না করার বিষয়টি নিশ্চিত করে এবং এমন একটি ট্রিগার চয়ন করে যা ব্যবসায়ের পারফরম্যান্স ব্যয়ের সাথে ভারসাম্য বজায় রাখে।
ট্রিগারগুলি জাভাস্ক্রিপ্ট কোড যা ট্যাগ ম্যানেজারের আকার এবং সম্পাদন ব্যয় বাড়ায়। বেশিরভাগ ট্রিগারগুলি ছোট হলেও, ক্রমবর্ধমান প্রভাব যুক্ত করতে পারে। উদাহরণস্বরূপ, বেশ কয়েকটি ক্লিক ইভেন্ট বা টাইমার ট্রিগার থাকা নাটকীয়ভাবে ট্যাগ ম্যানেজারের কাজের চাপ বাড়িয়ে তুলতে পারে।
একটি উপযুক্ত ট্রিগার ইভেন্ট চয়ন করুন
একটি ট্যাগের পারফরম্যান্স প্রভাব পৃথক হতে পারে। সাধারণভাবে, আগে যে ট্যাগ আগুন লাগে, তত বেশি এটি কর্মক্ষমতাকে প্রভাবিত করে। প্রাথমিক পৃষ্ঠার লোডের সময় সংস্থানগুলি সাধারণত সীমাবদ্ধ থাকে এবং তাই কোনও নির্দিষ্ট সংস্থান (বা ট্যাগ) লোড করা বা সম্পাদন করা সংস্থানগুলি অন্য কিছু থেকে দূরে নিয়ে যায়।
যদিও সমস্ত ট্যাগের জন্য উপযুক্ত ট্রিগারগুলি চয়ন করা গুরুত্বপূর্ণ, তবে এটি বিশেষত ট্যাগগুলির জন্য গুরুত্বপূর্ণ যা বড় সংস্থান লোড করে বা দীর্ঘ স্ক্রিপ্টগুলি সম্পাদন করে।
ট্যাগগুলি পৃষ্ঠা ভিউগুলিতে ট্রিগার করা যেতে পারে (সাধারণত Page load
, DOM Ready
, Window Loaded
) বা কাস্টম ইভেন্টের ভিত্তিতে। পৃষ্ঠার লোডকে প্রভাবিত করতে এড়াতে, Window Loaded
পরে অ-অপরিহার্য ট্যাগগুলি ফায়ার করুন।
কাস্টম ইভেন্টগুলি ব্যবহার করুন
গুগল ট্যাগ ম্যানেজারের অন্তর্নির্মিত ট্রিগারগুলির দ্বারা আচ্ছাদিত নয় এমন পৃষ্ঠা ইভেন্টগুলির প্রতিক্রিয়া হিসাবে ফায়ার ট্রিগারগুলির জন্য কাস্টম ইভেন্টগুলি ব্যবহার করুন। উদাহরণস্বরূপ, অনেক ট্যাগ পৃষ্ঠা ভিউ ট্রিগার ব্যবহার করে। যাইহোক, DOM Ready
এবং Window Loaded
মধ্যে সময়টি দীর্ঘ হতে পারে, এইভাবে কোনও ট্যাগ আগুন লাগলে সূক্ষ্ম-সুরে অসুবিধা হয়। কাস্টম ইভেন্টগুলি এই সমস্যার সমাধান হতে পারে।
প্রথমে একটি কাস্টম ইভেন্ট ট্রিগার তৈরি করুন এবং এই ট্রিগারটি ব্যবহার করতে আপনার ট্যাগগুলি আপডেট করুন।
ট্রিগারটি গুলি চালানোর জন্য, সংশ্লিষ্ট ইভেন্টটিকে ডেটা স্তরে চাপুন।
// Custom event trigger that fires after 2 seconds
setTimeout(() => {
dataLayer.push({
'event' : 'my-custom-event'
});
}, 2000);
নির্দিষ্ট ট্রিগার শর্তগুলি ব্যবহার করুন
অপ্রয়োজনীয় হলে ফায়ারিং ট্যাগগুলি এড়াতে নির্দিষ্ট ট্রিগার শর্তগুলি সংজ্ঞায়িত করুন। এটি করার সহজতম এবং কার্যকর উপায়গুলির মধ্যে একটি হ'ল এটি নিশ্চিত করা যে কোনও ট্যাগ কেবল পৃষ্ঠাগুলিতে যেখানে এটি ব্যবহৃত হয় সেখানে আগুন লাগে।
ট্যাগ ফায়ারিং সীমাবদ্ধ করতে বিল্ট-ইন ভেরিয়েবলগুলি ট্রিগার শর্তে অন্তর্ভুক্ত করা যেতে পারে।
উপযুক্ত সময়ে আপনার ট্যাগ ম্যানেজারটি লোড করুন
ট্যাগ ম্যানেজার নিজেই লোড হয়ে গেলে আপনি সামঞ্জস্য করে কর্মক্ষমতা উন্নত করতে পারেন। ট্রিগারগুলি, তারা কীভাবে কনফিগার করা হোক না কেন, কোনও ট্যাগ ম্যানেজারের লোড না হওয়া পর্যন্ত গুলি চালাতে পারে না। আপনি যখন ট্যাগ ম্যানেজারটি লোড করেন তখন পরীক্ষা করুন, কারণ এটির সমান বা বৃহত্তর প্রভাব থাকতে পারে। এই সিদ্ধান্তটি একটি পৃষ্ঠায় সমস্ত ট্যাগকে প্রভাবিত করে।
পরে ট্যাগ ম্যানেজারটি লোড করে আপনি ভবিষ্যতের পারফরম্যান্সের সমস্যাগুলি এড়াতে পারেন, কারণ এটি অজান্তেই খুব তাড়াতাড়ি কোনও ট্যাগ লোড করা প্রতিরোধ করে।
ভেরিয়েবল
পৃষ্ঠা থেকে ডেটা পড়তে ভেরিয়েবলগুলি ব্যবহার করুন। এগুলি ট্রিগারগুলিতে এবং ট্যাগগুলিতে নিজেরাই দরকারী।
ট্রিগারগুলির মতো, ভেরিয়েবলগুলি ট্যাগ ম্যানেজারে জাভাস্ক্রিপ্ট কোড যুক্ত করে এবং এইভাবে পারফরম্যান্সের সমস্যা তৈরি করতে পারে। ভেরিয়েবলগুলি তুলনামূলকভাবে ছোট হতে পারে, যেমন ইউআরএল, কুকিজ, ডেটা স্তর বা ডোমের অংশগুলি পড়ার কোড। এগুলি কাস্টম জাভাস্ক্রিপ্টও অন্তর্ভুক্ত করতে পারে যার সীমাহীন ক্ষমতা (এবং আকার) রয়েছে।
ন্যূনতম পরিবর্তনশীল ব্যবহার রাখুন, কারণ তারা ক্রমাগত ট্যাগ ম্যানেজার দ্বারা মূল্যায়ন করা হয়। ট্যাগ ম্যানেজার স্ক্রিপ্টের আকার এবং এটি ব্যবহার করার প্রক্রিয়াজাতকরণের সময় উভয়ই হ্রাস করতে ব্যবহৃত হয় না এমন পুরানো ভেরিয়েবলগুলি সরান।
ট্যাগ ব্যবস্থাপনা
ট্যাগগুলি ব্যবহার করে দক্ষতার সাথে পারফরম্যান্স সমস্যার ঝুঁকি হ্রাস করে।
ডেটা স্তর ব্যবহার করুন
ডেটা স্তরটি এমন একটি জাভাস্ক্রিপ্ট অ্যারে যা পৃষ্ঠা সম্পর্কে তথ্য ধারণ করে। এই অবজেক্টগুলিতে আপনি গুগল ট্যাগ ম্যানেজারের কাছে যেতে চান এমন সমস্ত তথ্য রয়েছে।
ডেটা স্তরটি ট্যাগগুলি ট্রিগার করতেও ব্যবহার করা যেতে পারে।
// Contents of the data layer
window.dataLayer = [{
'pageCategory': 'signup',
'visitorType': 'high-value'
}];
// Pushing a variable to the data layer
window.dataLayer.push({'variable_name': 'variable_value'});
// Pushing an event to the data layer
window.dataLayer.push({'event': 'event_name'});
যদিও গুগল ট্যাগ ম্যানেজার ডেটা স্তর ছাড়াই ব্যবহার করা যেতে পারে তবে এর দৃ strongly ়ভাবে প্রস্তাবিত। ডেটা স্তরটি তৃতীয় পক্ষের স্ক্রিপ্টগুলি দ্বারা একক স্থানে অ্যাক্সেস করা যেতে পারে এমন ডেটা একীভূত করে, এইভাবে এর ব্যবহারে আরও ভাল দৃশ্যমানতা সরবরাহ করে। অন্যান্য জিনিসগুলির মধ্যে, এটি অপ্রয়োজনীয় পরিবর্তনশীল গণনা এবং স্ক্রিপ্ট সম্পাদন হ্রাস করতে সহায়তা করতে পারে।
একটি ডেটা স্তর ব্যবহার করে, আপনি সম্পূর্ণ জাভাস্ক্রিপ্ট ভেরিয়েবল বা ডিওএম অ্যাক্সেস না দিয়ে ট্যাগ দ্বারা কোন ডেটা অ্যাক্সেস করা হয় তা নিয়ন্ত্রণ করতে পারেন।
ডেটা স্তরটির পারফরম্যান্স সুবিধাগুলি স্বজ্ঞাত নাও হতে পারে, প্রদত্ত ডেটা স্তরটি আপডেট করার ফলে গুগল ট্যাগ ম্যানেজারকে সমস্ত ধারক ভেরিয়েবলগুলি পুনরায় মূল্যায়ন করতে এবং সম্ভাব্য ট্রিগার ট্যাগগুলি পুনর্নির্মাণ করতে পারে, যা জাভাস্ক্রিপ্ট এক্সিকিউশনকে জড়িত করে। যদিও ডেটা স্তরটির অপব্যবহার করা সম্ভব, সাধারণত বলতে গেলে, যদি ডেটা স্তরটি পারফরম্যান্স সমস্যার উত্স হিসাবে উপস্থিত হয় তবে ধারকটিতে নিজেই সম্ভবত পারফরম্যান্সের সমস্যা রয়েছে। ডেটা স্তর এই সমস্যাগুলি আরও স্পষ্ট করে তোলে।
সদৃশ এবং অব্যবহৃত ট্যাগগুলি সরান
কোনও ট্যাগ ম্যানেজারের মাধ্যমে ইনজেকশনের পাশাপাশি কোনও পৃষ্ঠার এইচটিএমএল মার্কআপে কোনও ট্যাগ অন্তর্ভুক্ত করা হলে সদৃশ ট্যাগগুলি ঘটতে পারে।
অব্যবহৃত ট্যাগগুলি ট্রিগার ব্যতিক্রম ব্যবহারের মাধ্যমে অবরুদ্ধ না করে বিরতি দেওয়া বা অপসারণ করা উচিত। একটি ট্যাগ বিরতি দেওয়া বা অপসারণ করা ধারক থেকে কোডটি সরিয়ে দেয়; ব্লক করা হয় না।
যখন অব্যবহৃত ট্যাগগুলি সরানো হয়, ট্রিগার এবং ভেরিয়েবলগুলিও সেগুলি অপসারণ করা যায় কিনা তা নির্ধারণ করার জন্য পর্যালোচনা করুন।
বিরতিযুক্ত ট্যাগগুলি ইমপ্যাক্ট কনটেইনার আকার, তবে ট্যাগগুলি সক্রিয় থাকাকালীন মোট পে -লোড ছোট।
তালিকাগুলি অনুমতি দিন এবং অস্বীকার করুন
কোনও পৃষ্ঠায় অনুমোদিত ট্যাগ, ট্রিগার এবং ভেরিয়েবলগুলিতে অত্যন্ত দানাদার বিধিনিষেধগুলি কনফিগার করতে তালিকাগুলি অনুমতি দিন এবং অস্বীকার করুন । এটি পারফরম্যান্সের সেরা অনুশীলন এবং অন্যান্য নীতিগুলি কার্যকর করতে সহায়তা করতে ব্যবহার করা যেতে পারে।
মঞ্জুরি দিন এবং অস্বীকার তালিকাগুলি ডেটা স্তরটির মাধ্যমে কনফিগার করা হয়েছে।
window.dataLayer = [{
'gtm.allowlist': ['<id>', '<id>', ...],
'gtm.blocklist': ['customScripts']
}];
উদাহরণস্বরূপ, আপনি কাস্টম এইচটিএমএল ট্যাগ, জাভাস্ক্রিপ্ট ভেরিয়েবল বা সরাসরি ডিওএম অ্যাক্সেস ব্যবহার প্রতিরোধ করতে পারেন। এর অর্থ হ'ল কেবলমাত্র পিক্সেল এবং পূর্বনির্ধারিত ট্যাগগুলি ডেটা স্তর থেকে ডেটা সহ ব্যবহার করা যেতে পারে। যদিও এটি সীমাবদ্ধ, এটি আরও বেশি পারফরম্যান্স এবং সুরক্ষিত ট্যাগ ম্যানেজার বাস্তবায়নের ফলস্বরূপ হতে পারে।
সার্ভার-সাইড ট্যাগিং ব্যবহার করার বিষয়টি বিবেচনা করুন
এটি সার্ভার-সাইড ট্যাগিংয়ে একটি স্যুইচ বিবেচনা করার মতো, বিশেষত বৃহত্তর সাইটগুলির জন্য যা তাদের ডেটার উপর আরও নিয়ন্ত্রণ চায়। সার্ভার-সাইড ট্যাগিং ক্লায়েন্ট থেকে বিক্রেতার কোড সরিয়ে দেয় এবং এটির সাথে ক্লায়েন্ট থেকে সার্ভারে অফলোডগুলি প্রসেসিং করে।
উদাহরণস্বরূপ, ক্লায়েন্ট-সাইড ট্যাগিং ব্যবহার করার সময়, একাধিক অ্যানালিটিক্স অ্যাকাউন্টগুলিতে ডেটা প্রেরণ করা জড়িত যে ক্লায়েন্ট প্রতিটি শেষ পয়েন্টের জন্য পৃথক অনুরোধ শুরু করে। সার্ভার-সাইড ট্যাগিংয়ের সাথে, ক্লায়েন্ট কর্তৃক সার্ভার-সাইড ধারকটিতে একটি একক অনুরোধ করা হয় এবং সেখান থেকে এই ডেটা বিভিন্ন বিশ্লেষণ অ্যাকাউন্টে ফরোয়ার্ড করা হয়।
মনে রাখবেন যে সার্ভার-সাইড ট্যাগিং কেবল কিছু ট্যাগের সাথে কাজ করে। ট্যাগের সামঞ্জস্যতা বিক্রেতার উপর নির্ভর করে পরিবর্তিত হয়।
আরও তথ্যের জন্য, সার্ভার-সাইড ট্যাগিংয়ের একটি ভূমিকা দেখুন।
পাত্রে
ট্যাগ পরিচালকরা সাধারণত একাধিক দৃষ্টান্তকে অনুমতি দেয়, প্রায়শই তাদের সেট আপের মধ্যে পাত্রে হিসাবে উল্লেখ করা হয়। একাধিক পাত্রে একটি ট্যাগ ম্যানেজার অ্যাকাউন্টের মধ্যে নিয়ন্ত্রণ করা যায়।
প্রতি পৃষ্ঠায় কেবল একটি ধারক ব্যবহার করুন
একক পৃষ্ঠায় একাধিক পাত্রে উল্লেখযোগ্য পারফরম্যান্স সমস্যা তৈরি করতে পারে, কারণ এটি অতিরিক্ত ওভারহেড এবং স্ক্রিপ্ট সম্পাদনের পরিচয় দেয়। খুব কমপক্ষে, এটি মূল ট্যাগ কোডটি নিজেই নকল করে যা এটি ধারকটির জাভাস্ক্রিপ্টের অংশ হিসাবে বিতরণ করা হয়েছে, ধারকগুলির মধ্যে পুনরায় ব্যবহার করা যায় না।
একাধিক পাত্রে কার্যকরভাবে ব্যবহার করা বিরল। যাইহোক, এমন উদাহরণ রয়েছে যখন এটি কাজ করতে পারে, যদি ভালভাবে নিয়ন্ত্রণ করা হয়। যেমন:
- একটি বৃহত ধারকটির চেয়ে হালকা "আর্লি লোড" ধারক এবং একটি ভারী "পরে লোড" ধারক সহ।
- কম প্রযুক্তিগত ব্যবহারকারীদের জন্য একটি সীমাবদ্ধ ধারক এবং কম সীমাবদ্ধ, তবে আরও দৃ ly ়ভাবে নিয়ন্ত্রিত, আরও জটিল ট্যাগগুলির জন্য ধারক ব্যবহার করা।
যদি আপনাকে প্রতি পৃষ্ঠায় একাধিক পাত্রে ব্যবহার করতে হয় তবে একাধিক পাত্রে স্থাপনের জন্য গুগল ট্যাগ ম্যানেজার গাইডেন্স অনুসরণ করুন ।
প্রয়োজনে পৃথক পাত্রে ব্যবহার করুন
আপনি যদি একাধিক বৈশিষ্ট্যের জন্য যেমন কোনও ওয়েব অ্যাপ্লিকেশন এবং একটি মোবাইল অ্যাপ্লিকেশন ব্যবহার করেন তবে আপনি যে পাত্রে ব্যবহার করেন তা আপনার কর্মপ্রবাহের উত্পাদনশীলতাকে সহায়তা করতে বা আঘাত করতে পারে। এটি পারফরম্যান্সকেও প্রভাবিত করতে পারে।
যদি সাইটগুলি ব্যবহার এবং কাঠামোর সাথে একই রকম হয় তবে একটি একক ধারক কার্যকরভাবে একাধিক সাইটে ব্যবহার করা যেতে পারে। উদাহরণস্বরূপ, যদিও কোনও ব্র্যান্ডের মোবাইল এবং ওয়েব অ্যাপ্লিকেশনগুলি অনুরূপ ফাংশনগুলি পরিবেশন করতে পারে তবে সম্ভবত অ্যাপ্লিকেশনগুলি আলাদাভাবে কাঠামোগত করা হয়েছে এবং তাই আরও কার্যকরভাবে পৃথক পাত্রে পরিচালিত হয়েছে।
একটি একক ধারককে খুব বিস্তৃতভাবে পুনরায় ব্যবহার করা ট্যাগ এবং ট্রিগারগুলি পরিচালনা করতে জটিল যুক্তি জোর করে ধারকটির জটিলতা এবং আকার বাড়িয়ে তুলতে পারে।
ধারক আকারে নজর রাখুন
একটি ধারকটির আকার তার ট্যাগ, ট্রিগার এবং ভেরিয়েবল দ্বারা নির্ধারিত হয়। যদিও একটি ছোট ধারক এখনও পৃষ্ঠার পারফরম্যান্সকে নেতিবাচকভাবে প্রভাবিত করতে পারে, তবে একটি বৃহত ধারক প্রায় অবশ্যই হবে।
আপনার ট্যাগ ব্যবহারকে অনুকূল করার সময় ধারক আকারটি সবচেয়ে গুরুত্বপূর্ণ মেট্রিক হওয়া উচিত নয়। যাইহোক, একটি বৃহত ধারক আকার প্রায়শই একটি সতর্কতা চিহ্ন যা একটি ধারক ভালভাবে রক্ষণাবেক্ষণ করা হয় না এবং সম্ভবত অপব্যবহার করা হয় না।
গুগল ট্যাগ ম্যানেজার ধারক আকারকে 300 কেবি সীমাবদ্ধ করে এবং আকারের সীমাটির 70% পৌঁছানোর পরে ধারক আকার সম্পর্কে সতর্ক করে।
বেশিরভাগ সাইটের লক্ষ্য তাদের পাত্রে সীমাবদ্ধতার চেয়ে ছোট রাখার লক্ষ্য করা উচিত। তুলনার জন্য, মিডিয়ান সাইটের ধারকটি প্রায় 50 কেবি। নিজেই, গুগল ট্যাগ ম্যানেজার লাইব্রেরি প্রায় 33 কেবি সংকুচিত।
আপনার ধারক সংস্করণগুলির নাম দিন
একটি ধারক সংস্করণ হ'ল একটি নির্দিষ্ট সময়ে একটি ধারক সামগ্রীর একটি স্ন্যাপশট। একটি অর্থবহ নাম ব্যবহার করা এবং এর মধ্যে অর্থবহ পরিবর্তনের একটি সংক্ষিপ্ত বিবরণ সহ ভবিষ্যতের পারফরম্যান্সের সমস্যাগুলি ডিবাগ করা আরও সহজ করে তুলতে দীর্ঘ পথ যেতে পারে।
ট্যাগ ওয়ার্কফ্লো
আপনার ট্যাগগুলিতে পরিবর্তনগুলি পরিচালনা করা গুরুত্বপূর্ণ যাতে তারা পৃষ্ঠার পারফরম্যান্সে নেতিবাচক প্রভাব না ফেলে।
মোতায়েনের আগে পরীক্ষা
সমস্যাগুলি, পারফরম্যান্স এবং অন্যথায়, তারা শিপিংয়ের আগে মোতায়েনের আগে আপনার ট্যাগগুলি পরীক্ষা করুন।
ট্যাগ পরীক্ষা করার সময় বিবেচনা করার বিষয়গুলির মধ্যে রয়েছে:
- ট্যাগটি কি সঠিকভাবে কাজ করছে?
- ট্যাগটি কি কোনও লেআউট শিফট দেয়?
- ট্যাগ কি কোনও সংস্থান লোড করে? এই সংস্থানগুলি কত বড়?
- ট্যাগটি কি দীর্ঘ-চলমান স্ক্রিপ্টকে ট্রিগার করে?
প্রিভিউ মোড
পূর্বরূপ মোড আপনাকে প্রথমে জনসাধারণের কাছে স্থাপন না করে আপনার আসল সাইটে ট্যাগ পরিবর্তনগুলি পরীক্ষা করতে দেয়। পূর্বরূপ মোডে একটি ডিবাগিং কনসোল অন্তর্ভুক্ত যা ট্যাগ সম্পর্কে তথ্য সরবরাহ করে।
ডিবাগিং কনসোলে তথ্য প্রকাশের জন্য অতিরিক্ত ওভারহেডের কারণে পূর্বরূপ মোডে চালানোর সময় গুগল ট্যাগ ম্যানেজারের এক্সিকিউশন সময়টি আলাদা (কিছুটা ধীর) হয়। সুতরাং, উত্পাদনে সংগৃহীত প্রাকদর্শন মোডে সংগৃহীত ওয়েব ভাইটাল পরিমাপের তুলনা করা সুপারিশ করা হয় না। যাইহোক, এই তাত্পর্যটি ট্যাগগুলির সম্পাদনের আচরণকে নিজেরাই প্রভাবিত করবে না।
স্ট্যান্ডেলোন টেস্টিং
টেস্টিং ট্যাগগুলির বিকল্প পদ্ধতির একটি একক ট্যাগ সহ একটি ধারকযুক্ত একটি খালি পৃষ্ঠা সেট আপ করা - আপনি যে ট্যাগটি পরীক্ষা করছেন। এই টেস্টিং সেটআপটি কম বাস্তববাদী এবং কিছু সমস্যা ধরবে না (উদাহরণস্বরূপ, কোনও ট্যাগ লেআউট শিফট সৃষ্টি করে কিনা) - তবে এটি স্ক্রিপ্ট এক্সিকিউশনের মতো বিষয়গুলিতে ট্যাগের প্রভাবকে বিচ্ছিন্ন ও পরিমাপ করা সহজ করে তুলতে পারে। তৃতীয় পক্ষের কোডের কার্যকারিতা উন্নত করতে টেলিগ্রাফ কীভাবে এই বিচ্ছিন্নতা পদ্ধতির ব্যবহার করে তা দেখুন।
ট্যাগ পারফরম্যান্স মনিটর
গুগল ট্যাগ ম্যানেজার মনিটরিং এপিআই কোনও নির্দিষ্ট ট্যাগের কার্যকরকরণের সময় সম্পর্কে তথ্য সংগ্রহ করতে ব্যবহার করা যেতে পারে। এই তথ্যটি আপনার পছন্দের শেষ পয়েন্টে রিপোর্ট করা হয়েছে।
আরও তথ্যের জন্য, কীভাবে একটি গুগল ট্যাগ ম্যানেজার মনিটর তৈরি করবেন তা দেখুন।
ধারক পরিবর্তনের জন্য অনুমোদনের প্রয়োজন
প্রথম পক্ষের কোডটি সাধারণত স্থাপনার আগে পর্যালোচনা এবং পরীক্ষার মাধ্যমে যায়। আপনার ট্যাগগুলি একই আচরণ করুন।
দ্বি-পদক্ষেপ যাচাইকরণ যুক্ত করা, যার জন্য ধারক পরিবর্তনের জন্য প্রশাসকের অনুমোদনের প্রয়োজন, এটি করার এক উপায়। বিকল্পভাবে, আপনি যদি দ্বি-পদক্ষেপের যাচাইয়ের প্রয়োজন না করতে চান তবে এখনও পরিবর্তনগুলিতে নজর রাখতে চান, আপনি আপনার পছন্দের ধারক ইভেন্টগুলি সম্পর্কে ইমেল সতর্কতা পেতে ধারক বিজ্ঞপ্তিগুলি সেট আপ করতে পারেন।
পর্যায়ক্রমে অডিট ট্যাগ ব্যবহার
ট্যাগগুলির সাথে কাজ করার অন্যতম চ্যালেঞ্জ হ'ল তারা সময়ের সাথে সাথে জমে থাকে: ট্যাগগুলি যুক্ত হয় তবে খুব কমই সরানো হয়। পর্যায়ক্রমে অডিটিং ট্যাগগুলি এই প্রবণতাটি বিপরীত করার একটি উপায়। এটি করার জন্য আদর্শ ফ্রিকোয়েন্সি আপনার সাইটের ট্যাগগুলি কতবার আপডেট হয় তার উপর নির্ভর করে।
প্রতিটি ট্যাগকে লেবেল করা যাতে মালিক স্পষ্টতই সেই ট্যাগটির জন্য কে প্রতিক্রিয়াশীল তা সহজ সনাক্তকরণের অনুমতি দেয় এবং এটি এখনও প্রয়োজন কিনা তা বলতে পারে।
ট্যাগগুলি নিরীক্ষণ করার সময়, ট্রিগার এবং ভেরিয়েবলগুলি পরিষ্কার করতে ভুলবেন না। এগুলি প্রায়শই পারফরম্যান্স সমস্যার কারণ হতে পারে।
আরও তথ্যের জন্য, তৃতীয় পক্ষের স্ক্রিপ্টগুলি নিয়ন্ত্রণে রাখা দেখুন।