Google chrome extension 简单Chrome扩展:在新选项卡中打开url

Google chrome extension 简单Chrome扩展:在新选项卡中打开url,google-chrome-extension,Google Chrome Extension,我想创建一个“新标签”扩展,比如:用户可以打开一个新标签,里面有我的网站,还有一个隐藏的url 我已经用awesome生成了我的包,下面是我的manifest.json: manifest.json { "name": "My app", "version": "0.0.1", "manifest_version": 2, "description": "My awesome app", "homepage_url": "http://myapp.com", "icons

我想创建一个“新标签”扩展,比如:用户可以打开一个新标签,里面有我的网站,还有一个隐藏的url

我已经用awesome生成了我的包,下面是我的
manifest.json

manifest.json

{
  "name": "My app",
  "version": "0.0.1",
  "manifest_version": 2,
  "description": "My awesome app",
  "homepage_url": "http://myapp.com",
  "icons": {
    "16": "icons/icon16.png",
    "48": "icons/icon48.png",
    "128": "icons/icon128.png"
  },
  "default_locale": "en",
  "background": {
    "scripts": [
      "src/bg/background.js"
    ],
    "persistent": false
  },
  "permissions": [
    "tabs",
    "http://myapp.com/*"
  ]
}
我的
background.js
来自哪里,问题似乎非常相似

background.js

chrome.browserAction.onClicked.addListener(function(activeTab) {
  var newURL = "http://myapp.com";
  chrome.tabs.create({ url: newURL });
});
当我尝试从扩展设置运行后台页面时,仍然会遇到此错误:
uncaughttypeerror:无法读取未定义的属性“onClicked”

当我打开一个新的标签时,谷歌浏览器占了上风,给我显示了一个谷歌搜索页面


我做错了,我不知道如何/在哪里/为什么这是因为您需要在清单中注册浏览器操作。这是您的清单,底部添加了浏览器操作

{
  "name": "My app",
  "version": "0.0.1",
  "manifest_version": 2,
  "description": "My awesome app",
  "homepage_url": "http://myapp.com",
  "icons": {
    "16": "icons/icon16.png",
    "48": "icons/icon48.png",
    "128": "icons/icon128.png"
  },
  "default_locale": "en",
  "background": {
    "scripts": [
      "src/bg/background.js"
    ],
    "persistent": false
  },
  "permissions": [
    "tabs",
    "http://myapp.com/*"
  ],
  "browser_action": {}
}

以下是浏览器操作文档:

您完全偏离了轨道。您不想打开一个(简单的)新标签页,您想替换“新标签页”。
正确地解释了代码无法工作的原因,但它无法实现您想要的功能

要替换Chrome的新选项卡页面,您需要使用:


myPage.html
中,您可以为远程内容添加

清单中的
“浏览器操作”
字段在哪里?
chrome.browserAction.onClicked.addListener
在单击浏览器操作图标时启动,而不是以其他方式打开新选项卡。那是。。不是用户想要的。他需要的是一个新的标签覆盖。仔细阅读问题。
  "chrome_url_overrides" : {
    "newtab": "myPage.html"
  },