বর্ণনা
চলমান নেভিগেশন অনুরোধগুলোর অবস্থা সম্পর্কে বিজ্ঞপ্তি পেতে chrome.webNavigation API ব্যবহার করুন।
অনুমতি
webNavigationপ্রকাশ
chrome.webNavigation সমস্ত মেথড এবং ইভেন্ট ব্যবহার করার জন্য আপনাকে এক্সটেনশন ম্যানিফেস্টে 'webNavigation' পারমিশনটি ডিক্লেয়ার করতে হবে। উদাহরণস্বরূপ:
{
"name": "My extension",
...
"permissions": [
"webNavigation"
],
...
}
ঘটনার ক্রম
সফলভাবে সম্পন্ন হওয়া নেভিগেশনের জন্য, ইভেন্টগুলো নিম্নলিখিত ক্রমে ফায়ার হয়:
onBeforeNavigate -> onCommitted -> [onDOMContentLoaded] -> onCompleted
প্রক্রিয়া চলাকালীন যেকোনো ত্রুটি ঘটলে একটি onErrorOccurred ইভেন্ট ঘটে। একটি নির্দিষ্ট নেভিগেশনের ক্ষেত্রে, onErrorOccurred পরে আর কোনো ইভেন্ট ফায়ার হয় না।
যদি কোনো নেভিগেটিং ফ্রেমে সাবফ্রেম থাকে, তবে এর onCommitted এর যেকোনো চাইল্ড ফ্রেমের onBeforeNavigate ইভেন্টের আগে ফায়ার হয়; অপরদিকে, onCompleted ইভেন্টটি এর সমস্ত চাইল্ড ফ্রেমের onCompleted পরে ফায়ার হয়।
যদি কোনো ফ্রেমের রেফারেন্স ফ্র্যাগমেন্ট পরিবর্তিত হয়, তাহলে একটি onReferenceFragmentUpdated ইভেন্ট ফায়ার হয়। এই ইভেন্টটি onDOMContentLoaded পরে যেকোনো সময়, এমনকি onCompleted পরেও ফায়ার হতে পারে।
যদি কোনো ফ্রেমের অবস্থা পরিবর্তন করার জন্য হিস্ট্রি এপিআই ব্যবহার করা হয় (যেমন history.pushState() ব্যবহার করে), তাহলে একটি onHistoryStateUpdated ইভেন্ট ফায়ার হয়। এই ইভেন্টটি onDOMContentLoaded পরে যেকোনো সময় ফায়ার হতে পারে।
যদি কোনো নেভিগেশন ব্যাক ফরওয়ার্ড ক্যাশ থেকে একটি পেজ পুনরুদ্ধার করে, তাহলে onDOMContentLoaded ইভেন্টটি ফায়ার হবে না। ইভেন্টটি ফায়ার হয় না কারণ পেজটি প্রথমবার ভিজিট করার সময়ই কন্টেন্টের লোড সম্পন্ন হয়ে যায়।
যদি Chrome Instant বা Instant Pages-এর মাধ্যমে কোনো নেভিগেশন চালু করা হয়, তাহলে সম্পূর্ণ লোড হওয়া একটি পেজ বর্তমান ট্যাবে চলে আসে। সেক্ষেত্রে, একটি onTabReplaced ইভেন্ট ফায়ার হয়।
webRequest ইভেন্টগুলির সাথে সম্পর্ক
webRequest API এবং webNavigation API-এর ইভেন্টগুলোর মধ্যে কোনো নির্দিষ্ট ক্রম নেই। এমনটা হতে পারে যে, যে ফ্রেমগুলোতে ইতিমধ্যেই নতুন নেভিগেশন শুরু হয়ে গেছে, সেগুলোর জন্যও webRequest ইভেন্ট পাওয়া যায়, অথবা নেটওয়ার্ক রিসোর্স সম্পূর্ণরূপে লোড হওয়ার পরেই কেবল নেভিগেশনটি অগ্রসর হয়।
সাধারণত, webNavigation ইভেন্টগুলো UI-তে প্রদর্শিত ন্যাভিগেশন অবস্থার সাথে ঘনিষ্ঠভাবে সম্পর্কিত, অন্যদিকে webRequest ইভেন্টগুলো নেটওয়ার্ক স্ট্যাকের অবস্থার সাথে সম্পর্কিত যা সাধারণত ব্যবহারকারীর কাছে অস্পষ্ট থাকে।
ট্যাব আইডি
নেভিগেট করা সব ট্যাবই ক্রোমের UI-এর আসল ট্যাবের সাথে মেলে না, যেমন, একটি প্রি-রেন্ডার হওয়া ট্যাব। এই ধরনের ট্যাবগুলো ট্যাব এপিআই (tabs API) দিয়ে অ্যাক্সেস করা যায় না, এবং webNavigation.getFrame বা webNavigation.getAllFrames ব্যবহার করেও এগুলোর সম্পর্কে তথ্য পাওয়া যায় না। যখন এই ধরনের কোনো ট্যাব সোয়াপ করে আনা হয়, তখন একটি onTabReplaced ইভেন্ট ফায়ার হয় এবং সেগুলো এই এপিআইগুলোর মাধ্যমে অ্যাক্সেসযোগ্য হয়ে ওঠে।
টাইমস্ট্যাম্প
এটা মনে রাখা গুরুত্বপূর্ণ যে, অপারেটিং সিস্টেমের স্বতন্ত্র ক্রোম প্রসেসগুলো পরিচালনার ক্ষেত্রে কিছু প্রযুক্তিগত অস্বাভাবিকতার কারণে ব্রাউজার এবং এক্সটেনশন প্রসেসগুলোর মধ্যে ঘড়ির সময়ে অসামঞ্জস্য দেখা দিতে পারে। এর মানে হলো, WebNavigation-এর ইভেন্টগুলোর timeStamp প্রপার্টি শুধুমাত্র অভ্যন্তরীণভাবে সামঞ্জস্যপূর্ণ থাকার নিশ্চয়তা দেয়। একটি ইভেন্টের সাথে অন্য একটি ইভেন্টের তুলনা করলে তাদের মধ্যে সঠিক অফসেট পাওয়া যাবে, কিন্তু এক্সটেনশনের ভেতরের বর্তমান সময়ের সাথে তুলনা করলে (উদাহরণস্বরূপ (new Date()).getTime() এর মাধ্যমে) অপ্রত্যাশিত ফলাফল আসতে পারে।
ফ্রেম আইডি
একটি ট্যাবের ভেতরের ফ্রেমগুলোকে একটি ফ্রেম আইডি দ্বারা শনাক্ত করা যায়। মূল ফ্রেমের ফ্রেম আইডি সর্বদা ০ হয়, এবং চাইল্ড ফ্রেমগুলোর আইডি একটি ধনাত্মক সংখ্যা। একটি ফ্রেমে একবার কোনো ডকুমেন্ট তৈরি হয়ে গেলে, ডকুমেন্টটির জীবনকাল জুড়ে এর ফ্রেম আইডি অপরিবর্তিত থাকে। ক্রোম ৪৯ সংস্করণ থেকে, এই আইডিটি ফ্রেমটির জীবনকাল জুড়েও (একাধিক নেভিগেশনের ক্ষেত্রেও) অপরিবর্তিত থাকে।
ক্রোমের মাল্টি-প্রসেস বৈশিষ্ট্যের কারণে, একটি ট্যাব কোনো ওয়েব পেজের উৎস এবং গন্তব্য রেন্ডার করার জন্য ভিন্ন ভিন্ন প্রসেস ব্যবহার করতে পারে। সুতরাং, যদি একটি নতুন প্রসেসে নেভিগেশন সম্পন্ন হয়, তাহলে নতুন নেভিগেশনটি কমিট না হওয়া পর্যন্ত (অর্থাৎ নতুন মেইন ফ্রেমের জন্য onCommitted ইভেন্টটি পাঠানো না হওয়া পর্যন্ত) আপনি নতুন এবং পুরোনো উভয় পেজ থেকেই ইভেন্ট পেতে পারেন। অন্য কথায়, একই frameId অধীনে webNavigation ইভেন্টের একাধিক অপেক্ষমান ক্রম থাকা সম্ভব। এই ক্রমগুলোকে processId কী-এর মাধ্যমে আলাদা করা যায়।
আরও মনে রাখবেন যে, একটি সাময়িক লোডের সময় প্রসেসটি একাধিকবার পরিবর্তিত হতে পারে। লোডটি যখন অন্য কোনো সাইটে পুনঃনির্দেশিত হয়, তখন এমনটা ঘটে। এই ক্ষেত্রে, চূড়ান্ত onCommitted ইভেন্টটি না পাওয়া পর্যন্ত আপনি বারবার onBeforeNavigate এবং onErrorOccurred ইভেন্ট পেতে থাকবেন।
এক্সটেনশনের ক্ষেত্রে আরেকটি সমস্যাজনক ধারণা হলো ফ্রেমের লাইফসাইকেল। একটি ফ্রেম একটি ডকুমেন্ট ধারণ করে (যা একটি কমিটেড ইউআরএল-এর সাথে যুক্ত থাকে)। ডকুমেন্টটি পরিবর্তিত হতে পারে (যেমন নেভিগেট করার মাধ্যমে), কিন্তু ফ্রেমআইডি পরিবর্তিত হয় না। ফলে, শুধুমাত্র ফ্রেমআইডি ব্যবহার করে কোনো নির্দিষ্ট ডকুমেন্টে কী ঘটেছে তা নির্দিষ্ট করা কঠিন হয়ে পড়ে। আমরা ডকুমেন্টআইডি নামে একটি নতুন ধারণা চালু করছি, যা প্রতিটি ডকুমেন্টের জন্য একটি অনন্য শনাক্তকারী। যদি কোনো ফ্রেমে নেভিগেট করে একটি নতুন ডকুমেন্ট খোলা হয়, তবে এই শনাক্তকারীটি পরিবর্তিত হবে। পেজগুলো কখন তাদের লাইফসাইকেল অবস্থা পরিবর্তন করে (প্রি-রেন্ডার/অ্যাক্টিভ/ক্যাশড-এর মধ্যে) তা নির্ধারণ করার জন্য এই ফিল্ডটি কার্যকর, কারণ এটি অপরিবর্তিত থাকে।
রূপান্তরের প্রকারভেদ এবং যোগ্যতা
webNavigation API-এর onCommitted ইভেন্টের একটি transitionType এবং একটি transitionQualifiers প্রপার্টি রয়েছে। ট্রানজিশন টাইপটি history API- তে ব্যবহৃত টাইপের মতোই, যা বর্ণনা করে ব্রাউজারটি কীভাবে এই নির্দিষ্ট URL-টিতে নেভিগেট করেছে। এছাড়াও, বেশ কিছু ট্রানজিশন কোয়ালিফায়ার রিটার্ন করা যেতে পারে যা নেভিগেশনকে আরও সুনির্দিষ্ট করে।
নিম্নলিখিত রূপান্তর কোয়ালিফায়ারগুলো বিদ্যমান:
| রূপান্তর যোগ্যতা | বর্ণনা |
|---|---|
| "client_redirect" | ন্যাভিগেশনের সময় পেজে থাকা জাভাস্ক্রিপ্ট বা মেটা রিফ্রেশ ট্যাগের কারণে এক বা একাধিক রিডাইরেক্ট ঘটেছে। |
| "সার্ভার_পুনঃনির্দেশ" | ন্যাভিগেশন চলাকালীন সার্ভার থেকে পাঠানো HTTP হেডারের কারণে এক বা একাধিক রিডাইরেক্ট ঘটেছে। |
| "সামনে_পিছনে" | ব্যবহারকারী নেভিগেশন শুরু করার জন্য ফরওয়ার্ড বা ব্যাক বাটন ব্যবহার করেছেন। |
| "from_address_bar" | ব্যবহারকারী অ্যাড্রেস বার (যা অমনিবক্স নামেও পরিচিত) থেকে নেভিগেশন শুরু করেছেন। |
উদাহরণ
এই API-টি ব্যবহার করার জন্য, chrome-extension-samples রিপোজিটরি থেকে webNavigation API উদাহরণটি ইনস্টল করুন।
প্রকারভেদ
TransitionQualifier
এনাম
"ক্লায়েন্ট_পুনঃনির্দেশ" "সার্ভার_পুনঃনির্দেশ" "সামনে_পিছনে" "from_address_bar"
TransitionType
ন্যাভিগেশনের কারণ। হিস্ট্রি এপিআই-তে সংজ্ঞায়িত একই ট্রানজিশন টাইপগুলো ব্যবহার করা হয়। এগুলো হিস্ট্রি এপিআই -তে সংজ্ঞায়িত একই ট্রানজিশন টাইপ, তবে (পূর্ববর্তী সংস্করণের সাথে সামঞ্জস্যের জন্য) "auto_toplevel" এর পরিবর্তে "start_page" ব্যবহার করা হয়েছে।
এনাম
"লিঙ্ক" "typed" "স্বয়ংক্রিয়_বুকমার্ক" "auto_subframe" "ম্যানুয়াল_সাবফ্রেম" "উৎপাদিত" "স্টার্ট_পেজ" "ফর্ম_জমা" "পুনরায় লোড করুন" "কীওয়ার্ড" "কীওয়ার্ড_জেনারেটেড"
পদ্ধতি
getAllFrames()
chrome.webNavigation.getAllFrames(
details: object,
callback?: function,
): Promise<object[] | undefined>
প্রদত্ত ট্যাবের সমস্ত ফ্রেমের তথ্য পুনরুদ্ধার করে।
প্যারামিটার
- বিস্তারিত
বস্তু
যে ট্যাব থেকে সমস্ত ফ্রেম সংগ্রহ করা যাবে, সে সম্পর্কিত তথ্য।
- ট্যাবআইডি
সংখ্যা
ট্যাবটির আইডি।
- কলব্যাক
ফাংশন ঐচ্ছিক
callbackপ্যারামিটারটি দেখতে এইরকম:(details?: object[]) => void
- বিস্তারিত
object[] optional
প্রদত্ত ট্যাবের ফ্রেমগুলোর একটি তালিকা; নির্দিষ্ট ট্যাব আইডিটি অবৈধ হলে তালিকাটি null থাকবে।
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+A UUID of the document loaded.
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
The lifecycle the document is in.
- ত্রুটি ঘটেছে
বুলিয়ান
এই ফ্রেমে সর্বশেষ নেভিগেশন কোনো ত্রুটির কারণে বাধাগ্রস্ত হলে, অর্থাৎ onErrorOccurred ইভেন্টটি ফায়ার হলে, এর মান হবে True।
- ফ্রেমআইডি
সংখ্যা
ফ্রেমের আইডি। ০ নির্দেশ করে এটি মূল ফ্রেম; একটি ধনাত্মক মান সাবফ্রেমের আইডি নির্দেশ করে।
- frameTypeক্রোম ১০৬+
যে ধরনের ফ্রেমে নেভিগেশনটি সংঘটিত হয়েছিল।
- প্যারেন্টডকুমেন্টআইডি
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - প্রক্রিয়া আইডি
সংখ্যা
যে প্রসেসটি এই ফ্রেমের জন্য রেন্ডারার চালায়, তার আইডি।
- ইউআরএল
স্ট্রিং
এই ফ্রেমের সাথে বর্তমানে যুক্ত ইউআরএল।
ফেরত
Promise<object[] | undefined>
Chrome 93+প্রমিস শুধুমাত্র ম্যানিফেস্ট ভি৩ এবং এর পরবর্তী সংস্করণগুলোতে সমর্থিত, অন্যান্য প্ল্যাটফর্মে কলব্যাক ব্যবহার করতে হবে।
getFrame()
chrome.webNavigation.getFrame(
details: object,
callback?: function,
): Promise<object | undefined>
প্রদত্ত ফ্রেম সম্পর্কিত তথ্য পুনরুদ্ধার করে। ফ্রেম বলতে কোনো ওয়েব পেজের একটি <iframe> বা <frame>-কে বোঝায় এবং এটি একটি ট্যাব আইডি ও একটি ফ্রেম আইডি দ্বারা চিহ্নিত করা হয়।
প্যারামিটার
- বিস্তারিত
বস্তু
যে ফ্রেমটি সম্পর্কে তথ্য পুনরুদ্ধার করতে হবে, সেটির তথ্য।
- ডকুমেন্ট আইডি
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+ডকুমেন্টটির UUID। যদি frameId এবং/অথবা tabId প্রদান করা হয়, তবে প্রদত্ত ডকুমেন্ট আইডি দ্বারা প্রাপ্ত ডকুমেন্টের সাথে মেলানোর জন্য সেগুলোকে যাচাই করা হবে।
- ফ্রেমআইডি
সংখ্যা ঐচ্ছিক
The ID of the frame in the given tab.
- processId
সংখ্যা ঐচ্ছিক
ক্রোম ৪৯ থেকে বাতিল করা হয়েছেফ্রেমগুলো এখন তাদের ট্যাব আইডি এবং ফ্রেম আইডি দ্বারা স্বতন্ত্রভাবে চিহ্নিত করা হয়; প্রসেস আইডির আর প্রয়োজন নেই এবং তাই এটি উপেক্ষা করা হয়।
যে প্রসেসটি এই ট্যাবের রেন্ডারারটি চালায়, তার আইডি।
- ট্যাবআইডি
সংখ্যা ঐচ্ছিক
যে ট্যাবে ফ্রেমটি রয়েছে, সেই ট্যাবের আইডি।
- কলব্যাক
ফাংশন ঐচ্ছিক
callbackপ্যারামিটারটি দেখতে এইরকম:(details?: object) => void
- বিস্তারিত
বস্তু ঐচ্ছিক
অনুরোধকৃত ফ্রেম সম্পর্কিত তথ্য; নির্দিষ্ট ফ্রেম আইডি এবং/অথবা ট্যাব আইডি অবৈধ হলে এটি null হবে।
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+লোড করা ডকুমেন্টটির UUID।
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
ডকুমেন্টটি যে জীবনচক্রে রয়েছে।
- ত্রুটি ঘটেছে
বুলিয়ান
এই ফ্রেমে সর্বশেষ নেভিগেশন কোনো ত্রুটির কারণে বাধাগ্রস্ত হলে, অর্থাৎ onErrorOccurred ইভেন্টটি ফায়ার হলে, এর মান হবে True।
- ফ্রেমটাইপক্রোম ১০৬+
The type of frame the navigation occurred in.
- প্যারেন্টডকুমেন্টআইডি
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - ইউআরএল
স্ট্রিং
এই ফ্রেমের সাথে বর্তমানে যুক্ত URL, যদি frameId দ্বারা চিহ্নিত ফ্রেমটি প্রদত্ত ট্যাবে কোনো এক সময়ে বিদ্যমান থেকে থাকে। একটি নির্দিষ্ট frameId-এর সাথে একটি URL যুক্ত থাকার অর্থ এই নয় যে সংশ্লিষ্ট ফ্রেমটি এখনও বিদ্যমান আছে।
ফেরত
Promise<object | undefined>
ক্রোম ৯৩+প্রমিস শুধুমাত্র ম্যানিফেস্ট ভি৩ এবং এর পরবর্তী সংস্করণগুলোতে সমর্থিত, অন্যান্য প্ল্যাটফর্মে কলব্যাক ব্যবহার করতে হবে।
ইভেন্টগুলি
onBeforeNavigate
chrome.webNavigation.onBeforeNavigate.addListener(
callback: function,
filters?: object,
)
Fired when a navigation is about to occur.
প্যারামিটার
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
বস্তু
- ক্রোম ১০৬+
ডকুমেন্টটি যে জীবনচক্রে রয়েছে।
সংখ্যা
০ নির্দেশ করে যে নেভিগেশন ট্যাব কন্টেন্ট উইন্ডোতে সংঘটিত হয়; একটি ধনাত্মক মান সাবফ্রেমে নেভিগেশন নির্দেশ করে। একটি নির্দিষ্ট ট্যাব এবং প্রসেসের জন্য ফ্রেম আইডিগুলো অনন্য হয়।
- ক্রোম ১০৬+
The type of frame the navigation occurred in.
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
সংখ্যা
প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1।সংখ্যা
ক্রোম ৫০ থেকে বাতিল করা হয়েছেএই ইভেন্টের জন্য processId আর সেট করা হয় না, কারণ যে প্রসেসটি ফলাফলস্বরূপ ডকুমেন্টটি রেন্ডার করবে, তা onCommit-এর আগে জানা যায় না।
-১ এর মান।
সংখ্যা
যে ট্যাবে নেভিগেশন করা হবে, তার আইডি।
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে সেই সময়, যখন ব্রাউজারটি নেভিগেশন শুরু করতে যাচ্ছিল।
স্ট্রিং
বস্তু ঐচ্ছিক
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onCommitted
chrome.webNavigation.onCommitted.addListener(
callback: function,
filters?: object,
)
যখন কোনো নেভিগেশন সম্পন্ন হয়, তখন এটি ট্রিগার হয়। ডকুমেন্টটি (এবং এর সাথে সম্পর্কিত রিসোর্স, যেমন ছবি ও সাবফ্রেম) তখনও ডাউনলোড হতে পারে, কিন্তু ডকুমেন্টের অন্তত কিছু অংশ সার্ভার থেকে পাওয়া গেছে এবং ব্রাউজার নতুন ডকুমেন্টটিতে সুইচ করার সিদ্ধান্ত নিয়েছে।
প্যারামিটার
- কলব্যাক
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
- বিস্তারিত
বস্তু
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+লোড করা ডকুমেন্টটির UUID।
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
ডকুমেন্টটি যে জীবনচক্রে রয়েছে।
- ফ্রেমআইডি
সংখ্যা
০ নির্দেশ করে যে নেভিগেশন ট্যাব কন্টেন্ট উইন্ডোতে সংঘটিত হয়; একটি ধনাত্মক মান সাবফ্রেমে নেভিগেশন নির্দেশ করে। একটি ট্যাবের মধ্যে ফ্রেম আইডিগুলো অনন্য হয়।
- ফ্রেমটাইপক্রোম ১০৬+
যে ধরনের ফ্রেমে নেভিগেশনটি সংঘটিত হয়েছিল।
- প্যারেন্টডকুমেন্টআইডি
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
ক্রোম ৭৪+প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - প্রক্রিয়া আইডি
সংখ্যা
যে প্রসেসটি এই ফ্রেমের জন্য রেন্ডারার চালায়, তার আইডি।
- ট্যাবআইডি
সংখ্যা
যে ট্যাবে নেভিগেশনটি ঘটে, তার আইডি।
- টাইমস্ট্যাম্প
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে, নেভিগেশনটি সম্পন্ন হওয়ার সময়।
- ট্রানজিশন কোয়ালিফায়ার
রূপান্তর যোগ্যতাসূচক শব্দসমূহের একটি তালিকা।
- transitionType
দিকনির্দেশনার কারণ।
- ইউআরএল
স্ট্রিং
- ফিল্টার
বস্তু ঐচ্ছিক
- ইউআরএল
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onCompleted
chrome.webNavigation.onCompleted.addListener(
callback: function,
filters?: object,
)
যখন কোনো ডকুমেন্ট, তার সাথে সম্পর্কিত রিসোর্সগুলো সহ, সম্পূর্ণরূপে লোড এবং ইনিশিয়ালাইজ করা হয়, তখন এই ফাংশনটি ট্রিগার হয়।
প্যারামিটার
- কলব্যাক
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
- বিস্তারিত
বস্তু
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+লোড করা ডকুমেন্টটির UUID।
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
ডকুমেন্টটি যে জীবনচক্রে রয়েছে।
- ফ্রেমআইডি
সংখ্যা
০ নির্দেশ করে যে নেভিগেশন ট্যাব কন্টেন্ট উইন্ডোতে সংঘটিত হয়; একটি ধনাত্মক মান সাবফ্রেমে নেভিগেশন নির্দেশ করে। একটি ট্যাবের মধ্যে ফ্রেম আইডিগুলো অনন্য হয়।
- ফ্রেমটাইপক্রোম ১০৬+
The type of frame the navigation occurred in.
- parentDocumentId
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
ক্রোম ৭৪+প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - প্রক্রিয়া আইডি
সংখ্যা
যে প্রসেসটি এই ফ্রেমের জন্য রেন্ডারার চালায়, তার আইডি।
- ট্যাবআইডি
সংখ্যা
যে ট্যাবে নেভিগেশনটি ঘটে, তার আইডি।
- টাইমস্ট্যাম্প
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে, ডকুমেন্টটি লোড হওয়া শেষ হওয়ার সময়।
- ইউআরএল
স্ট্রিং
- ফিল্টার
বস্তু ঐচ্ছিক
- ইউআরএল
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onCreatedNavigationTarget
chrome.webNavigation.onCreatedNavigationTarget.addListener(
callback: function,
filters?: object,
)
যখন নেভিগেশন হোস্ট করার জন্য একটি নতুন উইন্ডো, অথবা বিদ্যমান উইন্ডোর মধ্যে একটি নতুন ট্যাব তৈরি করা হয়, তখন এটি ট্রিগার হয়।
প্যারামিটার
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
বস্তু
সংখ্যা
sourceTabId সহ সেই ফ্রেমের আইডি, যেখানে নেভিগেশনটি চালু হয়। ০ মূল ফ্রেমকে নির্দেশ করে।
সংখ্যা
যে প্রসেসটি সোর্স ফ্রেমের জন্য রেন্ডারার চালায়, তার আইডি।
সংখ্যা
যে ট্যাবে নেভিগেশনটি চালু করা হয়, তার আইডি।
সংখ্যা
যে ট্যাবে ইউআরএলটি খোলা হয়েছে তার আইডি
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে সেই সময়, যখন ব্রাউজারটি একটি নতুন ভিউ তৈরি করতে যাচ্ছিল।
স্ট্রিং
ইউআরএলটি নতুন উইন্ডোতে খোলা হবে।
বস্তু ঐচ্ছিক
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onDOMContentLoaded
chrome.webNavigation.onDOMContentLoaded.addListener(
callback: function,
filters?: object,
)
যখন পেজের DOM সম্পূর্ণরূপে নির্মিত হয়ে যায়, কিন্তু উল্লেখিত রিসোর্সগুলো পুরোপুরি লোড নাও হতে পারে, তখন এটি ট্রিগার হয়।
প্যারামিটার
- কলব্যাক
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
- বিস্তারিত
বস্তু
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+A UUID of the document loaded.
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
ডকুমেন্টটি যে জীবনচক্রে রয়েছে।
- ফ্রেমআইডি
সংখ্যা
০ নির্দেশ করে যে নেভিগেশন ট্যাব কন্টেন্ট উইন্ডোতে সংঘটিত হয়; একটি ধনাত্মক মান সাবফ্রেমে নেভিগেশন নির্দেশ করে। একটি ট্যাবের মধ্যে ফ্রেম আইডিগুলো অনন্য হয়।
- ফ্রেমটাইপক্রোম ১০৬+
যে ধরনের ফ্রেমে নেভিগেশনটি সংঘটিত হয়েছিল।
- parentDocumentId
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
ক্রোম ৭৪+প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - প্রক্রিয়া আইডি
সংখ্যা
যে প্রসেসটি এই ফ্রেমের জন্য রেন্ডারার চালায়, তার আইডি।
- ট্যাবআইডি
সংখ্যা
যে ট্যাবে নেভিগেশনটি ঘটে, তার আইডি।
- টাইমস্ট্যাম্প
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে, যে সময়ে পেজটির DOM সম্পূর্ণরূপে নির্মিত হয়েছিল।
- ইউআরএল
স্ট্রিং
- ফিল্টার
বস্তু ঐচ্ছিক
- ইউআরএল
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onErrorOccurred
chrome.webNavigation.onErrorOccurred.addListener(
callback: function,
filters?: object,
)
যখন কোনো ত্রুটি ঘটে এবং নেভিগেশন বাতিল করা হয়, তখন এটি সক্রিয় হয়। এটি ঘটতে পারে যদি কোনো নেটওয়ার্ক ত্রুটি ঘটে, অথবা ব্যবহারকারী নেভিগেশন বাতিল করেন।
প্যারামিটার
- কলব্যাক
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
- বিস্তারিত
বস্তু
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+লোড করা ডকুমেন্টটির UUID।
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
The lifecycle the document is in.
- ত্রুটি
স্ট্রিং
ত্রুটির বিবরণ।
- ফ্রেমআইডি
সংখ্যা
০ নির্দেশ করে যে নেভিগেশন ট্যাব কন্টেন্ট উইন্ডোতে সংঘটিত হয়; একটি ধনাত্মক মান সাবফ্রেমে নেভিগেশন নির্দেশ করে। একটি ট্যাবের মধ্যে ফ্রেম আইডিগুলো অনন্য হয়।
- ফ্রেমটাইপক্রোম ১০৬+
যে ধরনের ফ্রেমে নেভিগেশনটি সংঘটিত হয়েছিল।
- প্যারেন্টডকুমেন্টআইডি
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
ক্রোম ৭৪+প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - প্রক্রিয়া আইডি
সংখ্যা
ক্রোম ৫০ থেকে বাতিল করা হয়েছেএই ইভেন্টের জন্য processId আর সেট করা নেই।
-১ এর মান।
- ট্যাবআইডি
সংখ্যা
যে ট্যাবে নেভিগেশনটি ঘটে, তার আইডি।
- টাইমস্ট্যাম্প
সংখ্যা
ইপক থেকে ত্রুটি ঘটার সময়, যা মিলিসেকেন্ডে পরিমাপ করা হয়েছে।
- ইউআরএল
স্ট্রিং
- ফিল্টার
বস্তু ঐচ্ছিক
- ইউআরএল
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onHistoryStateUpdated
chrome.webNavigation.onHistoryStateUpdated.addListener(
callback: function,
filters?: object,
)
যখন ফ্রেমের হিস্ট্রি একটি নতুন URL-এ আপডেট করা হয়, তখন এটি ট্রিগার হয়। ঐ ফ্রেমের জন্য ভবিষ্যতের সমস্ত ইভেন্ট আপডেট করা URL-টি ব্যবহার করবে।
প্যারামিটার
- কলব্যাক
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
- বিস্তারিত
বস্তু
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+লোড করা ডকুমেন্টটির UUID।
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
The lifecycle the document is in.
- ফ্রেমআইডি
সংখ্যা
০ নির্দেশ করে যে নেভিগেশন ট্যাব কন্টেন্ট উইন্ডোতে সংঘটিত হয়; একটি ধনাত্মক মান সাবফ্রেমে নেভিগেশন নির্দেশ করে। একটি ট্যাবের মধ্যে ফ্রেম আইডিগুলো অনন্য হয়।
- ফ্রেমটাইপক্রোম ১০৬+
যে ধরনের ফ্রেমে নেভিগেশনটি সংঘটিত হয়েছিল।
- প্যারেন্টডকুমেন্টআইডি
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
ক্রোম ৭৪+প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - প্রক্রিয়া আইডি
সংখ্যা
যে প্রসেসটি এই ফ্রেমের জন্য রেন্ডারার চালায়, তার আইডি।
- ট্যাবআইডি
সংখ্যা
যে ট্যাবে নেভিগেশনটি ঘটে, তার আইডি।
- টাইমস্ট্যাম্প
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে, নেভিগেশনটি সম্পন্ন হওয়ার সময়।
- ট্রানজিশন কোয়ালিফায়ার
রূপান্তর যোগ্যতাসূচক শব্দসমূহের একটি তালিকা।
- রূপান্তর প্রকার
দিকনির্দেশনার কারণ।
- ইউআরএল
স্ট্রিং
- ফিল্টার
বস্তু ঐচ্ছিক
- ইউআরএল
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onReferenceFragmentUpdated
chrome.webNavigation.onReferenceFragmentUpdated.addListener(
callback: function,
filters?: object,
)
যখন কোনো ফ্রেমের রেফারেন্স ফ্র্যাগমেন্ট আপডেট করা হয়, তখন এটি ট্রিগার হয়। ঐ ফ্রেমের জন্য ভবিষ্যতের সমস্ত ইভেন্টে আপডেট করা URL-টি ব্যবহৃত হবে।
প্যারামিটার
- কলব্যাক
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
- বিস্তারিত
বস্তু
- ডকুমেন্ট আইডি
স্ট্রিং
ক্রোম ১০৬+লোড করা ডকুমেন্টটির UUID।
- ডকুমেন্ট লাইফসাইকেলক্রোম ১০৬+
ডকুমেন্টটি যে জীবনচক্রে রয়েছে।
- ফ্রেমআইডি
সংখ্যা
০ নির্দেশ করে যে নেভিগেশন ট্যাব কন্টেন্ট উইন্ডোতে সংঘটিত হয়; একটি ধনাত্মক মান সাবফ্রেমে নেভিগেশন নির্দেশ করে। একটি ট্যাবের মধ্যে ফ্রেম আইডিগুলো অনন্য হয়।
- ফ্রেমটাইপক্রোম ১০৬+
যে ধরনের ফ্রেমে নেভিগেশনটি সংঘটিত হয়েছিল।
- প্যারেন্টডকুমেন্টআইডি
স্ট্রিং ঐচ্ছিক
ক্রোম ১০৬+এই ফ্রেমটির মালিক প্যারেন্ট ডকুমেন্টের একটি UUID। যদি কোনো প্যারেন্ট না থাকে, তবে এটি সেট করা হয় না।
- parentFrameId
সংখ্যা
ক্রোম ৭৪+প্যারেন্ট ফ্রেমের আইডি, অথবা এটি মূল ফ্রেম হলে
-1। - প্রক্রিয়া আইডি
সংখ্যা
যে প্রসেসটি এই ফ্রেমের জন্য রেন্ডারার চালায়, তার আইডি।
- ট্যাবআইডি
সংখ্যা
যে ট্যাবে নেভিগেশনটি ঘটে, তার আইডি।
- টাইমস্ট্যাম্প
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে, নেভিগেশনটি সম্পন্ন হওয়ার সময়।
- ট্রানজিশন কোয়ালিফায়ার
রূপান্তর যোগ্যতাসূচক শব্দসমূহের একটি তালিকা।
- রূপান্তর প্রকার
দিকনির্দেশনার কারণ।
- ইউআরএল
স্ট্রিং
- ফিল্টার
বস্তু ঐচ্ছিক
- ইউআরএল
যে URL-টিতে নেভিগেট করা হচ্ছে, সেটিকে অবশ্যই যে শর্তগুলো পূরণ করতে হবে। এই ইভেন্টের জন্য UrlFilter-এর 'schemes' এবং 'ports' ফিল্ডগুলো উপেক্ষা করা হয়।
onTabReplaced
chrome.webNavigation.onTabReplaced.addListener(
callback: function,
)
যখন ট্যাবের বিষয়বস্তু একটি ভিন্ন (সাধারণত পূর্বে প্রি-রেন্ডার করা) ট্যাব দ্বারা প্রতিস্থাপিত হয়, তখন এটি কার্যকর হয়।
প্যারামিটার
- কলব্যাক
ফাংশন
callbackপ্যারামিটারটি দেখতে এইরকম:(details: object) => void
- বিস্তারিত
বস্তু
- প্রতিস্থাপিত ট্যাবআইডি
সংখ্যা
যে ট্যাবটি প্রতিস্থাপন করা হয়েছিল তার আইডি।
- ট্যাবআইডি
সংখ্যা
যে ট্যাবটি পুরোনো ট্যাবটিকে প্রতিস্থাপন করেছে, তার আইডি।
- টাইমস্ট্যাম্প
সংখ্যা
ইপক থেকে মিলিসেকেন্ডে প্রতিস্থাপনটি ঘটার সময়।