Проблема в том, что JavaScript внутри скриптов контента работает в собственной изолированной среде и имеет доступ только к другому JavaScript, который был загружен одним из двух способов:
Через манифест :
{
"name": "My extension",
...
"content_scripts": [
{
"js": ["https://connect.facebook.net/en_US/all.js"]
}
],
...
}
Или используя Программный впрыск :
/* in background.html */
chrome.browserAction.onClicked.addListener(function(tab) {
chrome.tabs.executeScript(null,
{file:"https://connect.facebook.net/en_US/all.js"});
});
Обязательно обновите разрешения манифеста:
/* in manifest.json */
"permissions": [
"tabs", "https://connect.facebook.net"
],
При добавлении тега скрипта будет оцениваться JavaScript в контексте содержащейся страницы вне песочницы JavaScript, к которой у вашего JavaScript есть доступ.
Кроме того, поскольку сценарий FB требует, чтобы в DOM присутствовал «fb-root», вам, вероятно, потребуется использовать программный подход, чтобы вы могли сначала обновить DOM с помощью элемента, а затем передать сообщение вернуться на фоновую страницу, чтобы загрузить сценарий Facebook, чтобы он был доступен для JavaScript, загруженного в сценарии содержимого.