Google Chrome扩展程序 - 无法使用CSS加载本地图像

Bja*_*son 92 css background-image google-chrome-extension

我有一个简单的Chrome扩展程序,它使用内容脚本功能来修改网站.更具体地说,background-image所述网站.

出于某种原因,我似乎无法使用本地图像,即使它们被包装在扩展中.

body {
    background: #000 url('image.jpg') !important;
    background-repeat: repeat !important;
}
Run Code Online (Sandbox Code Playgroud)

就是这样,最简单的CSS ......但它不起作用.浏览器不加载图像.

小智 241

Chrome具有i18n支持 ,可以在CSS中引用您的扩展程序.我将图像保存在扩展中的图像文件夹中,因此CSS中的引用资源如下所示:

background-image:url('chrome-extension://__MSG_@@extension_id__/images/main.png');
Run Code Online (Sandbox Code Playgroud)

  • 谢谢,这正是我想要的.只是一个脚注:请记住,您需要在清单文件中将您的资产声明为web_accessible_resources(如此处所述:http://code.google.com/chrome/extensions/manifest.html#web_accessible_resources).否则他们将无法加载 (36认同)
  • 太棒了.这是一个很好的解决方案,确实适用于未打包和打包的扩展 - 感谢分享一个非常好的提示. (4认同)
  • 我意识到一件事!永远不要认为接受的答案是该问题的唯一正确解决方案!当我看到接受的答案时,我担心我必须进行硬编码,但在看到你的答案后,我告诉自己这个人拯救了我的一天!!;-) (2认同)

ser*_*erg 67

您的图片网址应如下 chrome-extension://<EXTENSION_ID>/image.jpg

你最好通过javascript替换css.来自docs:

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

  • @Salem因为否则您需要在css中对您的扩展ID进行硬编码. (7认同)
  • @Salem开发为解压缩的扩展ID并上传到图库有一个不同的ID是不方便的.这不是世界末日,只是不方便和一些不好的做法,就像在代码中硬编码绝对文件路径一样. (4认同)

rjb*_*rjb 34

这个问题有很多旧的答案和解决方案.

截至2015年8月(使用Chrome 45和Manifest版本2),目前用于链接到Chrome扩展程序中的本地图像的"最佳做法" 是以下方法.

1)使用扩展程序图像文件夹的相对路径链接到CSS中的资源:

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

2)将单个资产添加到扩展的manifest.json文件的web_accessible_resources部分:

"web_accessible_resources": [
  "images/file.png"
]
Run Code Online (Sandbox Code Playgroud)

注意:此方法适用于少数文件,但不能很好地扩展到许多文件.

相反,更好的方法是利用Chrome对匹配模式的支持,将给定目录中的所有文件列入白名单:

{
    "name": "Example Chrome Extension",
    "version": "0.1",
    "manifest_version": 2,
    ...    
    "web_accessible_resources": [
      "images/*"
    ]
}
Run Code Online (Sandbox Code Playgroud)

使用此方法,您可以使用本机支持的方法快速轻松地在Chrome扩展程序的CSS文件中使用图像.


小智 21

一种选择是您的图像转换为base64:

然后将数据放入你的css中:

body { background-image: url(...); }
Run Code Online (Sandbox Code Playgroud)

虽然这可能不是您在定期开发网页时想要使用的方法,但由于构建Chrome扩展程序的一些限制,这是一个很好的选择.


Fox*_*nni 19

我的解决方案

使用Menifest v2,您需要添加web_accessible_resources到文件中,然后将其chrome-extension://__MSG_@@extension_id__/images/pattern.png用作css文件中的URL.

CSS:

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

的manifest.json

{
  "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"
     ]
}
Run Code Online (Sandbox Code Playgroud)

ps你的manifest.json可能看起来与这个不同.


Tha*_*evn 8

此CSS版本仅适用于扩展环境(应用页面,弹出页面,背景页面,选项页面)以及content_scripts CSS文件.

在.less文件中,我总是在开头设置一个变量:

@extensionId : ~"__MSG_@@extension_id__";
Run Code Online (Sandbox Code Playgroud)

然后,如果要引用像图像这样的扩展本地资源,请使用:

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


小智 7

有一点需要提及的是,在web_accessible_resources中,您可以使用通配符.而不是

"图像/ pattern.png"

您可以使用

"图片/*"