গুগল ক্রোম এক্সটেনশনগুলি - সিএসএস সহ স্থানীয় চিত্রগুলি লোড করা যায় না


99

আমার একটি সহজ ক্রোম এক্সটেনশন রয়েছে যা কোনও ওয়েবসাইটকে সংশোধন করতে কন্টেন্ট স্ক্রিপ্ট বৈশিষ্ট্যটি ব্যবহার করে। আরও নির্দিষ্টভাবে, background-imageওয়েবসাইটটির।

কোনও কারণে আমি স্থানীয় চিত্রগুলি এক্সটেনশনে প্যাক করা সত্ত্বেও ব্যবহার করতে সক্ষম হতে পারছি না।

body {
    background: #000 url('image.jpg') !important;
    background-repeat: repeat !important;
}

এটি হ'ল, সহজ সিএসএস ... তবে এটি কার্যকর হবে না। ব্রাউজারটি চিত্রটি লোড করে না।


4
এক্সটেনশানটি কেন ইউআরএল ('image.jpg') স্থানীয় মনে করবে? আপনার কি পুরো পথের দরকার নেই?
ট্রেনিংমার

উত্তর:


72

আপনার চিত্র URL টি দেখতে হবে chrome-extension://<EXTENSION_ID>/image.jpg

জাভাস্ক্রিপ্টের মাধ্যমে সিএসএস প্রতিস্থাপন করা ভাল। ডক্স থেকে :

//Code for displaying <extensionDir>/images/myimage.png:
var imgURL = chrome.extension.getURL("images/myimage.png");
document.getElementById("someImage").src = imgURL;

7
@ সালেম কারণ অন্যথায় আপনাকে CSS এ আপনার এক্সটেনশন আইডি হার্ডকোড করতে হবে।
সার্জ

বোবা হতে হবে না, তবে কেন এটি একটি সমস্যা?
সালেম

4
@ সেলাম আনপ্যাকড এক্সটেনশন আইডি হিসাবে বিকশিত হওয়া অসুবিধা হবে এবং গ্যালারীটিতে আপলোড করা হবে যার বিভিন্ন আইডি রয়েছে। উদাহরণস্বরূপ কোডটিতে পরম ফাইল প্যাথগুলি হার্ডকডিং করার মতো, এটি কেবলমাত্র অসুবিধা এবং এক ধরণের খারাপ অনুশীলনের সমাপ্তি নয়।
সার্জ

আহ, বোধগম্য হয়। আমি এটিকে সমর্থন করি.
সালেম

যেহেতু এটি স্বীকৃত উত্তর, আপনার অন্য জবাব সম্পর্কে মন্তব্য দেখতে হবে যেখানে অরিরিরা স্থানীয় ফন্ট এবং চিত্রগুলি অ্যাক্সেস করতে আপনার ম্যানিফেস্ট ফাইলটিতে ওয়েব_অ্যাক্সেসিবল_সোর্সগুলি অন্তর্ভুক্ত করার বিষয়ে উল্লেখ করেছে।
আর্যান ফিরুজিয়ান

254

ক্রোমের আই 18 এন সমর্থন রয়েছে যা আপনার সিএসএসে আপনার এক্সটেনশানটিকে রেফারেন্স করার ক্ষমতা সরবরাহ করে। আমি আমার চিত্রগুলি এক্সটেনশনে একটি চিত্র ফোল্ডারে রাখি, তাই সিএসএসে রেসেট সম্পদগুলি এর মতো:

background-image:url('chrome-extension://__MSG_@@extension_id__/images/main.png');

4
ভাল একটা. এটি দুর্দান্ত সমাধান এবং আনপ্যাকড প্যাকেজড এবং প্যাকেজড এক্সটেনশন উভয়ের জন্যই কাজ করে - সত্যিই দুর্দান্ত টিপ ভাগ করে নেওয়ার জন্য ধন্যবাদ।
রিচার্ড হলিস

41
ধন্যবাদ, আমি ঠিক এটিই খুঁজছিলাম কেবল একটি পাদটীকা: মনে রাখবেন যে আপনার নিজের সম্পদগুলি আপনার ম্যানিফেস্ট ফাইলটিতে ওয়েব_অ্যাক্সেসিবল_সোর্স হিসাবে ঘোষণা করতে হবে (এখানে বর্ণিত হিসাবে: কোড . google.com/chrome/extensions/… )। অন্যথায় এগুলি লোড হবে না
অ্যারিরা

4
একটা জিনিস বুঝলাম! কখনই ভাবেন না গৃহীত উত্তরই সেই প্রশ্নের একমাত্র সঠিক সমাধান! আমি ভীত ছিলাম যখন আমি গৃহীত উত্তর দেখেছি তখন হার্ডকোড করতে হবে তবে আপনি উত্তরটি দেখার পরে আমি নিজেকে বলেছিলাম এই লোকটি আমার দিনটি বাঁচিয়েছে !! ;-)
রফিক মোহাম্মদ

এটি প্রায় সর্বদা এটি করার সর্বোত্তম উপায় is খাঁটি সিএসএস বনাম বনাম জাভাস্ক্রিপ্ট এবং সিএসএস একসাথে @serg উত্তরে মিলিয়ে দিন। এটি আমার মতে গ্রহণযোগ্য উত্তর হওয়া উচিত।
জেরেমি জের

@ অ্যারির লিঙ্কটি এখন এখানে রয়েছে: বিকাশকারী.চ্রোম
বেন

43

এই প্রশ্নের অনেক পুরানো উত্তর এবং সমাধান রয়েছে।

আগস্ট 2015 পর্যন্ত (ক্রোম 45 এবং ম্যানিফেস্ট সংস্করণ 2 ব্যবহার করে), ক্রোম এক্সটেনশানগুলির মধ্যে স্থানীয় চিত্রগুলির সাথে লিঙ্ক করার জন্য বর্তমান "সেরা অনুশীলন" নিম্নলিখিত পদ্ধতির।

1) আপনার এক্সটেনশনের চিত্রগুলির ফোল্ডারে কোনও আপেক্ষিক পথ ব্যবহার করে আপনার সিএসএসের সম্পদের সাথে লিঙ্ক করুন :

.selector {
    background: url('chrome-extension://__MSG_@@extension_id__/images/file.png');
}

2) আপনার এক্সটেনশনের ম্যানিফেস্ট.জসন ফাইলের ওয়েব_অ্যাক্সেসিবল_ রিসোর্স বিভাগে স্বতন্ত্র সম্পদ যুক্ত করুন:

"web_accessible_resources": [
  "images/file.png"
]

দ্রষ্টব্য: এই পদ্ধতিটি কয়েকটি ফাইলের জন্য উপযুক্ত তবে অনেকগুলি ফাইলের সাথে এটি ভাল স্কেল করে না।

পরিবর্তে, একটি আরও ভাল পদ্ধতি হ'ল প্রদত্ত ডিরেক্টরিতে সমস্ত ফাইলকে সাদা তালিকাভুক্ত করার জন্য ম্যাচের নিদর্শনগুলির জন্য ক্রোমের সমর্থন উপার্জন করা:

{
    "name": "Example Chrome Extension",
    "version": "0.1",
    "manifest_version": 2,
    ...    
    "web_accessible_resources": [
      "images/*"
    ]
}

এই পদ্ধতির ব্যবহার আপনাকে দেশীয় সমর্থিত পদ্ধতিগুলি ব্যবহার করে আপনার ক্রোম এক্সটেনশনের সিএসএস ফাইলে দ্রুত এবং অনায়াসে চিত্রগুলি ব্যবহার করার অনুমতি দেবে।


22

একটি বিকল্প হ'ল আপনার চিত্রকে বেস 64 এ রূপান্তর করা :

এবং তারপরে আপনার সিএসএসে ডেটা ঠিক রাখুন:

body { background-image: url(...); }

যদিও নিয়মিত ওয়েবপৃষ্ঠা বিকাশ করার সময় আপনি এটি ব্যবহার করতে চান এমন কোনও দৃষ্টিভঙ্গি নাও থাকতে পারে , ক্রোম এক্সটেনশন তৈরির কিছুটা প্রতিবন্ধকতার কারণে এটি দুর্দান্ত বিকল্প।


4
আমি এই বিকল্পটি পছন্দ করি। আমি একমত নই যে উপরে বর্ণিত পদ্ধতির মাধ্যমে গুগল সমস্ত চিত্রকে ইনজেকশন দেওয়ার পরামর্শ দেওয়ার জন্য সঠিক । বেস 64 অ্যাপ্রোচটিও দ্রুত। +1 !!!
18:51

20

আমার সমাধান।

ম্যানিফেস্ট ভি 2 এর সাহায্যে আপনাকে web_accessible_resourcesফাইলটিতে যুক্ত করতে হবে এবং তারপরে chrome-extension://__MSG_@@extension_id__/images/pattern.pngআপনার সিএসএস ফাইলে ইউআরএল হিসাবে ব্যবহার করতে হবে।

সিএসএস:

 #selector {
      background: #fff url('chrome-extension://__MSG_@@extension_id__/images/pattern.png'); 
 }

ম্যানিফেস্ট.জসন

{
  "manifest_version": 2,

  "name": "My Extension Name",
  "description": "My Description",
  "version": "1.0",

  "content_scripts": [
      {
        "matches": ["https://mydomain.com/*"],
        "css": ["style.css"]
      }
    ],

  "permissions": [
    "https://mydomain.com/"
  ],
  "browser_action": {
      "default_icon": {                    
            "19": "images/icon19.png",           
            "38": "images/icon38.png"          
       },
       "default_title": "My Extension Name"  
   },
   "web_accessible_resources": [
       "images/pattern.png"
     ]
}

পিএস আপনার ম্যানিফেস্ট.জসন এটির থেকে আলাদা দেখতে পারে।


9

এই সিএসএস-সংস্করণটি কেবল এক্সটেনশন পরিবেশে (অ্যাপ পৃষ্ঠা, পপআপ পৃষ্ঠা, ব্যাকগ্রাউন্ড পৃষ্ঠা, বিকল্প পৃষ্ঠা) পাশাপাশি কন্টেন্ট_স্ক্রিপ্ট CSS ফাইলগুলিতে কাজ করে।

.বিহীন ফাইলে, আমি সর্বদা শুরুতে একটি পরিবর্তনশীল সেট করি:

@extensionId : ~"__MSG_@@extension_id__";

তারপরে, আপনি যদি চিত্রগুলির মতো এক্সটেনশান-স্থানীয়-সংস্থানগুলি উল্লেখ করতে চান তবে ব্যবহার করুন:

.close{
    background-image: url("chrome-extension://@{extensionId}/images/close.png");
}

7

একটি বিষয় উল্লেখ করার জন্য হ'ল ওয়েব_অ্যাক্সেসযোগ্য_স্রোতে আপনি ওয়াইল্ডকার্ড ব্যবহার করতে পারেন। পরিবর্তে তাই

"চিত্র / প্যাটার্ন.পিএনজি"

তুমি ব্যবহার করতে পার

"চিত্র / *"


4

কেবলমাত্র ডকুমেন্টেশন অনুযায়ী স্পষ্ট করতে, একটি এক্সটেনশনের প্রতিটি ফাইলই এর মতো পরম URL দ্বারা অ্যাক্সেসযোগ্য:

ক্রোম-এক্সটেনশন: // <extensionID>/<pathToFile>

নোটটি <extensionID>হ'ল একটি অনন্য শনাক্তকারী যা প্রতিটি এক্সটেনশনের জন্য এক্সটেনশন সিস্টেম উত্পন্ন করে। আপনি URL ক্রোম: // এক্সটেনশনে গিয়ে আপনার সমস্ত লোডযুক্ত এক্সটেনশনের আইডি দেখতে পারেন । <pathToFile>এক্সটেনশন শীর্ষ ফোল্ডারের অধীনে ফাইলের অবস্থান হয়; এটি সম্পর্কিত ইউআরএল হিসাবে একই as

...

সিএসএসে পটভূমি চিত্র পরিবর্তন করা:

#id{পটভূমি-চিত্র: url (" chrome-extension://<extensionID>/<pathToFile>"); }


জাভাস্ক্রিপ্টের মাধ্যমে সিএসএসে পটভূমি চিত্র পরিবর্তন করা:

document.getElementById (' id') .style.backgroundImage = "url ('ক্রোম-এক্সটেনশন: // <extensionID>/ <pathToFile>')");


JQuery এর মাধ্যমে CSS এ পটভূমি চিত্র পরিবর্তন করা:

$ (" #id") .css ("পটভূমি-চিত্র", "ইউআরএল ('ক্রোম-এক্সটেনশন: // <extensionID>/ <pathToFile>')");

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.