ただ、Chrome Extensions では、manifest.json にタブの操作を許可する記述を加えないといけない。
★manifest.json
...
"permissions": ["tabs"],
...
"permissions": ["tabs"],
...
下記は Safari Extensions の場合と同様に、独自の form 要素の onsubmit で sendUrl() を指定し、その結果、入力ボックスで指定された URL にページ遷移を行う場合。
★content_scripts
// form 要素を挿入する
var testForm = document.createElement("form");
testForm.onsubmit = "test";
testForm.method = "post";
document.body.insertBefore(testForm, document.body.firstChild);
testForm.addEventListener("submit", sendUrl); // addEventListener で処理先を指定
// 入力ボックスを上記の testForm に生成する
var testInput = document.createElement("input");
testInput.type = "text";
testInput.id = "testInput";
testInput.name = "testInput";
testForm.appendChild(testInput);
// ボタンを上記の testForm に生成する
var testSubmit = document.createElement("input");
testSubmit.type = "submit";
testSubmit.value = "send";
testForm.appendChild(testSubmit);
// submit で送られてきた処理
function sendUrl() {
chrome.extension.sendRequest({action: "open", text: testInput.value});
}
var testForm = document.createElement("form");
testForm.onsubmit = "test";
testForm.method = "post";
document.body.insertBefore(testForm, document.body.firstChild);
testForm.addEventListener("submit", sendUrl); // addEventListener で処理先を指定
// 入力ボックスを上記の testForm に生成する
var testInput = document.createElement("input");
testInput.type = "text";
testInput.id = "testInput";
testInput.name = "testInput";
testForm.appendChild(testInput);
// ボタンを上記の testForm に生成する
var testSubmit = document.createElement("input");
testSubmit.type = "submit";
testSubmit.value = "send";
testForm.appendChild(testSubmit);
// submit で送られてきた処理
function sendUrl() {
chrome.extension.sendRequest({action: "open", text: testInput.value});
}
★background_page 内の Javascript
function GoTo(req, sender, callback) {
// 新規タブで開く場合
chrome.tabs.create({url: req.text, selected: false});
// 同じタブで開く場合
chrome.windows.getCurrent(function(w) {
chrome.tabs.getSelected(w.id, function(t) {
chrome.tabs.update(t.id, {url: req.text});
});
});
}
// content_scripts からの受信
chrome.extension.onRequest.addListener(GoTo);
// 新規タブで開く場合
chrome.tabs.create({url: req.text, selected: false});
// 同じタブで開く場合
chrome.windows.getCurrent(function(w) {
chrome.tabs.getSelected(w.id, function(t) {
chrome.tabs.update(t.id, {url: req.text});
});
});
}
// content_scripts からの受信
chrome.extension.onRequest.addListener(GoTo);
ちなみに、url に日本語が含まれる場合、このままでは遷移できないので、上記の sendUrl() 内の testInput.value をエンコードしてやる必要がある。
function sendUrl() {
chrome.extension.sendRequest({action: "open", text: encodeURI(testInput.value)});
}
chrome.extension.sendRequest({action: "open", text: encodeURI(testInput.value)});
}
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.