Safari Extension,直接从工具栏访问页面/内容?

时间:2011-09-23 07:41:56

标签: javascript safari safari-extension

是否可以直接从(Safari)工具栏访问网页内容?我现在可以从上下文菜单访问它,但不知道我如何获得与工具栏相同的功能。

这就是我得到的:

// 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);
     }
}

但是我如何直接从工具栏中找到这个内容?

2 个答案:

答案 0 :(得分:6)

好的,基本上它的工作原理如下:

  • 在全局中,执行performCommand(通过单击工具栏),调度事件
  • 此事件在handleGextText
  • 中捕获 在handleGextText中
  • ,你可以做你需要做的事情并调用safari.self.tab.dispatchMessage将事件调度回全局
  • 在全局范围内,事件被handleEvent
  • 捕获

>

// 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);          
        }
     }
}

答案 1 :(得分:1)

好的,很好找到了。我用消息解决了它。

我向'global'发送一条消息,该消息由注入的脚本捕获。该函数获取所选文本(将其放入userinfo),并将消息发送回全局。

多数民众赞成。