ম্যানিফেস্ট - বিষয়বস্তু স্ক্রিপ্ট

"content_scripts" কী একটি নির্দিষ্ট URL প্যাটার্নের সাথে মেলে এমন একটি পৃষ্ঠা খোলা হলে প্রতিবার ব্যবহার করার জন্য একটি স্ট্যাটিকভাবে লোড করা JavaScript বা CSS ফাইল নির্দিষ্ট করে। এক্সটেনশনগুলি প্রোগ্রাম্যাটিকভাবে বিষয়বস্তু স্ক্রিপ্টগুলিকে ইনজেক্ট করতে পারে, বিস্তারিত জানার জন্য স্ক্রিপ্ট ইনজেকশন দেখুন।

উদ্ভাসিত

এইগুলি "content_scripts" এর জন্য সমর্থিত কী। শুধুমাত্র "matches" কী এবং হয় "js" বা "css" প্রয়োজন।

manifest.json

{
 "name": "My extension",
 ...
 "content_scripts": [
   {
     "matches": ["https://*.example.com/*"],
     "css": ["my-styles.css"],
     "js": ["content-script.js"],
     "exclude_matches": ["*://*/*foo*"],
     "include_globs": ["*example.com/???s/*"],
     "exclude_globs": ["*bar*"],     
     "all_frames": false,
     "match_origin_as_fallback": false,
     "match_about_blank": false,
     "run_at": "document_idle",
     "world": "ISOLATED",
   }
 ],
 ...
}

ফাইল

প্রতিটি ফাইলে অবশ্যই এক্সটেনশনের রুট ডিরেক্টরিতে একটি রিসোর্সের একটি আপেক্ষিক পাথ থাকতে হবে৷ লিডিং স্ল্যাশ ( / ) স্বয়ংক্রিয়ভাবে ছাঁটা হয়। প্রতিটি ফাইল কখন ইনজেকশন করা হবে তা "run_at" কী নির্দিষ্ট করে।

"css" - অ্যারে
ঐচ্ছিক CSS ফাইল পাথের একটি অ্যারে, এই অ্যারের ক্রমানুসারে ইনজেক্ট করা হয় এবং কোনো DOM নির্মাণ বা পৃষ্ঠা রেন্ডারিং হওয়ার আগে।
"js" - অ্যারে,
ঐচ্ছিক জাভাস্ক্রিপ্ট ফাইল পাথগুলির একটি অ্যারে, সিএসএস ফাইলগুলি ইনজেকশন করার পরে এই অ্যারেতে প্রদর্শিত ক্রম অনুসারে ইনজেকশন করা হয়। অ্যারের প্রতিটি স্ট্রিং অবশ্যই এক্সটেনশনের রুট ডিরেক্টরির একটি সম্পদের আপেক্ষিক পথ হতে হবে। লিডিং স্ল্যাশ ('/') স্বয়ংক্রিয়ভাবে ছাঁটা হয়।

মিল ইউআরএল

শুধুমাত্র "matches" সম্পত্তি প্রয়োজন. তারপরে আপনি "exclude_matches" , "include_globs" , এবং "exclude_globs" ব্যবহার করতে পারেন কোন URL-এ কোড ইনজেক্ট করতে হবে তা কাস্টমাইজ করতে। "matches" কী একটি সতর্কতা ট্রিগার করবে।

"matches" - অ্যারে
প্রয়োজন কোন URL প্যাটার্নগুলি কন্টেন্ট স্ক্রিপ্টে ইনজেক্ট করতে হবে তা নির্দিষ্ট করে। সিনট্যাক্সের জন্য ম্যাচ প্যাটার্নস দেখুন।
"exclude_matches" - অ্যারে
ঐচ্ছিক কন্টেন্ট স্ক্রিপ্ট ইনজেক্ট করার জন্য URL প্যাটার্ন বাদ দেয়। সিনট্যাক্সের জন্য ম্যাচ প্যাটার্নস দেখুন।
"include_globs" - অ্যারে
ঐচ্ছিক এই গ্লোবের সাথে মেলে শুধুমাত্র সেই URLগুলি অন্তর্ভুক্ত করতে মিলের পরে প্রয়োগ করা হয়৷ @include Greasemonkey কীওয়ার্ড অনুকরণ করার উদ্দেশ্যে।
"exclude_globs" - অ্যারে
ঐচ্ছিক এই গ্লোবের সাথে মেলে এমন URLগুলি বাদ দিতে মিলের পরে প্রয়োগ করা হয়েছে৷ @exclude Greasemonkey কীওয়ার্ড অনুকরণ করার উদ্দেশ্যে।

গ্লোব ইউআরএল হল সেগুলি যাতে "ওয়াইল্ডকার্ড" * এবং প্রশ্ন চিহ্ন থাকে। ওয়াইল্ডকার্ড * একটি খালি স্ট্রিং সহ যেকোনো দৈর্ঘ্যের যেকোনো স্ট্রিংয়ের সাথে মেলে, যখন প্রশ্ন চিহ্ন ? যেকোনো একক অক্ষরের সাথে মিলে যায়।

বিষয়বস্তু স্ক্রিপ্ট একটি পৃষ্ঠায় ইনজেক্ট করা হয় যদি:

  • এর URL যেকোন "matches" এবং "include_globs" প্যাটার্নের সাথে মেলে।
  • এবং URLটি "exclude_matches" বা "exclude_globs" প্যাটার্নের সাথে মেলে না।

গ্লোব এবং ইউআরএল মেলানো উদাহরণ

"include_globs"

manifest.json

{
  ...
  "content_scripts": [
    {
      "matches": ["https://*.example.com/*"],
      "include_globs": ["https://???.example.com/foo/*"],
      "js": ["content-script.js"]
    }
  ],
  ...
}
মেলে
https://www.example.com/foo/bar
https://the.example.com/foo/
মেলে না
https://my.example.com/foo/bar
https://example.com/foo/*
https://www.example.com/foo

manifest.json

{
  ...
  "content_scripts": [
    {
      "matches": ["https://*.example.com/*"],
      "include_globs": ["*example.com/???s/*"],
      "js": ["content-script.js"]
    }
  ],
  ...
}
মেলে
https://www.example.com/arts/index.html
https://www.example.com/jobs/index.html
মেলে না
https://www.example.com/sports/index.html
https://www.example.com/music/index.html

"exclude_globs"

manifest.json

{
  ...
  "content_scripts": [
    {
      "matches": ["https://*.example.com/*"],
      "exclude_globs": ["*science*"],
      "js": ["content-script.js"]
    }
  ],
  ...
}
মেলে
https://history.example.com
https://.example.com/music
মেলে না
https://science.example.com
https://www.example.com/science

উন্নত কাস্টমাইজেশন উদাহরণ

manifest.json

{
  ...
  "content_scripts": [
    {
      "matches": ["https://*.example.com/*"],
      "exclude_matches": ["*://*/*business*"],
      "include_globs": ["*example.com/???s/*"],
      "exclude_globs": ["*science*"],
      "js": ["content-script.js"]
    }
  ],
  ...
}
মেলে
https://www.example.com/arts/index.html
https://.example.com/jobs/index.html
মেলে না
https://science.example.com
https://www.example.com/jobs/business
https://www.example.com/science

ফ্রেম

"all_frames" কী সুনির্দিষ্ট করে যে বিষয়বস্তু স্ক্রিপ্টটি নির্দিষ্ট URL প্রয়োজনীয়তার সাথে মেলে এমন সমস্ত ফ্রেমে ইনজেকশন করা উচিত কিনা। যদি false সেট করা হয় তবে এটি শুধুমাত্র শীর্ষস্থানীয় ফ্রেমে ইনজেক্ট করবে। একটি about:blank ফ্রেমে ইনজেক্ট করতে এটি "match_about_blank" এর সাথে ব্যবহার করা যেতে পারে।

data: , blob: , এবং filesystem: মতো অন্যান্য ফ্রেমে ইনজেক্ট করতে, "match_origin_as_fallback" কে true সেট করুন। বিস্তারিত জানার জন্য, সম্পর্কিত ফ্রেমে ইনজেকশন দেখুন

"all_frames" বুলিয়ান
ঐচ্ছিক ডিফল্ট থেকে false , যার অর্থ শুধুমাত্র উপরের ফ্রেমটি মিলেছে৷ সত্য হিসাবে সেট করা হলে, এটি সমস্ত ফ্রেমে ইনজেকশন করবে, এমনকি ফ্রেমটি ট্যাবের শীর্ষস্থানীয় ফ্রেম না হলেও। প্রতিটি ফ্রেম ইউআরএলের প্রয়োজনীয়তার জন্য স্বাধীনভাবে চেক করা হয়, ইউআরএলের প্রয়োজনীয়তা পূরণ না হলে এটি চাইল্ড ফ্রেমে প্রবেশ করাবে না।
"match_about_blank" - বুলিয়ান
ঐচ্ছিক ডিফল্ট থেকে false । স্ক্রিপ্টটি একটি about:blank ফ্রেমে ইনজেক্ট করা উচিত যেখানে প্যারেন্ট URL "matches" -এ ঘোষিত প্যাটার্নগুলির একটির সাথে মেলে।
"match_origin_as_fallback" - বুলিয়ান
ঐচ্ছিক ডিফল্ট থেকে false । স্ক্রিপ্টটি এমন ফ্রেমে ইনজেক্ট করা উচিত যা একটি মিলিত উত্স দ্বারা তৈরি করা হয়েছিল, তবে যার URL বা উত্স সরাসরি প্যাটার্নের সাথে মেলে না৷ এর মধ্যে রয়েছে বিভিন্ন স্কিম সহ ফ্রেম, যেমন about: , data: , blob: , এবং filesystem: .

রান টাইম এবং এক্সিকিউশন এনভায়রনমেন্ট

ডিফল্টরূপে, নথি এবং সমস্ত সংস্থান লোড করা শেষ হলে বিষয়বস্তু স্ক্রিপ্টগুলি ইনজেকশন করা হয় এবং একটি ব্যক্তিগত বিচ্ছিন্ন কার্যকরী পরিবেশে বাস করে যা পৃষ্ঠা বা অন্যান্য এক্সটেনশনগুলিতে অ্যাক্সেসযোগ্য নয়। আপনি নিম্নলিখিত কীগুলিতে এই ডিফল্টগুলি পরিবর্তন করতে পারেন:

"run_at" - document_start | document_end | document_idle
ঐচ্ছিক স্ক্রিপ্ট কখন পৃষ্ঠায় ইনজেকশন করা উচিত তা নির্দিষ্ট করে। এটি Document.readyState এর লোডিং অবস্থার সাথে মিলে যায়:
  • "document_start" : DOM এখনও লোড হচ্ছে।
  • "document_end" : পৃষ্ঠার সংস্থানগুলি এখনও লোড হচ্ছে৷
  • "document_idle" : DOM এবং সংস্থানগুলি লোড করা শেষ হয়েছে৷ এটি ডিফল্ট।
"world" - ISOLATED | MAIN
ঐচ্ছিক একটি স্ক্রিপ্টের মধ্যে চালানোর জন্য জাভাস্ক্রিপ্ট বিশ্ব। ডিফল্ট "ISOLATED" , যা এক্সিকিউশন এনভায়রনমেন্ট কন্টেন্ট স্ক্রিপ্টের জন্য অনন্য। "MAIN" ওয়ার্ল্ড বেছে নেওয়ার মানে হল স্ক্রিপ্টটি হোস্ট পেজের জাভাস্ক্রিপ্টের সাথে এক্সিকিউশন এনভায়রনমেন্ট শেয়ার করবে। আরও জানতে বিচ্ছিন্ন বিশ্বে কাজ দেখুন।

উদাহরণ

ম্যানিফেস্টে একটি বিষয়বস্তু স্ক্রিপ্ট ইনজেক্ট করে এমন একটি এক্সটেনশন তৈরি করতে প্রতিটি পৃষ্ঠার টিউটোরিয়ালটিতে রান দেখুন।