Rog*_*ger 3 javascript safari safari-extension
是否可以直接从(Safari)工具栏访问Web内容?我现在可以从上下文菜单访问它,但不知道我如何获得与工具栏相同的功能.
这就是我得到的:
// injected
document.addEventListener("contextmenu", handleMessage, false);
function handleMessage(msgEvent) {
var sel = '';
sel = window.parent.getSelection()+'';
safari.self.tab.setContextMenuEventUserInfo(msgEvent, sel);
}
// global
safari.application .addEventListener("command", performCommand, false);
function performCommand(event) {
console.log('performCommand');
if (event.command == "abc") {
var query = event.userInfo;
console.log(query);
alert(query);
}
}
Run Code Online (Sandbox Code Playgroud)
但是我如何直接从工具栏中获取这些内容?
好的,基本上它的工作原理如下:
>
// Global Script
safari.application.addEventListener("command", performCommand, false);
safari.application.addEventListener("message", handleEvent, false);
// send message
function performCommand(event) {
console.log('command:' + event.command);
if (event.command == "abc") {
console.log("msg: my message");
safari.application.activeBrowserWindow.activeTab.page.dispatchMessage("msg", "do-something");
}
}
function handleEvent(event) {
var messageName = event.name;
console.log("evenname:" + event.name);
if (messageName === "did-something") {
var msg = event.message;
// do something
}
}
// Injected Script
if (window.top === window) { // inject only once!
console.log("add event listners [injected.js]");
safari.self.addEventListener("message", handleGextText, false);
}
function handleGextText(event) {
console.log("evenname:" + event.name);
console.log("evenmsg :" + event.message);
var messageName = event.name;
var messageData = event.message;
if (messageName === "msg") {
if (messageData === "do-something") {
console.log('msg received: ' + event.name);
var sel = '';
// do what you need to do and dispatch message back to Global
console.log("send message to toolbar");
safari.self.tab.dispatchMessage("did-something", sel);
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2566 次 |
| 最近记录: |