How to call Greasemonkey#39;s GM_ functions from code that must run in the target page scope?(如何从必须在目标页面范围内运行的代码中调用 Greasemonkey 的 GM_ 函数?)
问题描述
我在这里问了一个问题并得到了答案:如何调用Greasemonkey 的这个 YouTube 功能?
I asked a question and got an answer here: How to call this YouTube function from Greasemonkey?
该代码有效,并向页面添加了一个按钮,用于捕获视频时间.
但是,关键部分必须在目标页面范围内运行——Greasemonkey 的 GM_
函数不可用.
That code works and adds a button to the page, which captures the video time.
But, the key part must run in the target-page scope -- where Greasemonkey's GM_
functions are not available.
我想用 GM_setValue()
来记录视频时间.如何从按钮的 click
处理程序中调用 GM_setValue()
?
I want to use GM_setValue()
to record the video time. How do I call GM_setValue()
from my button's click
handler?
这里是完整脚本的相关部分(右键保存):
... ...
//-- Only run in the top page, not the various iframes.
if (window.top === window.self) {
var timeBtn = document.createElement ('a');
timeBtn.id = "gmTimeBtn";
timeBtn.textContent = "Time";
//-- Button is styled using CSS, in GM_addStyle, below.
document.body.appendChild (timeBtn);
addJS_Node (null, null, activateTimeButton);
}
function activateTimeButton () {
var timeBtn = document.getElementById ("gmTimeBtn");
if (timeBtn) {
timeBtn.addEventListener ('click',
function () {
var ytplayer = document.getElementById ("movie_player");
//-- IMPORTANT: GM_functions will not work here.
console.log ("getCurrentTime(): ", ytplayer.getCurrentTime() );
alert (ytplayer.getCurrentTime() );
},
false
);
}
else {
alert ("Time button not found!");
}
}
... ...
谢谢你:-)
推荐答案
从必须在页面范围内运行的代码中使用 Greasemonkey 的 GM_
函数(例如您的 timeBtn
单击处理程序),请执行以下操作:
To use Greasemonkey's GM_
functions from code that must run in the page scope (Such as your timeBtn
click handler), do the following:
- 让页面范围代码使用
postMessage
以字符串格式发送数据. - 让 Greasemonkey 脚本监听相应的消息,并使用消息数据调用所需的
GM_
函数. - 使用 JSON 安全地将数据打包成字符串.
- Have the page-scope code use
postMessage
to send the data in string format. - Have the Greasemonkey script listen for the appropriate messages and call the desired
GM_
function(s) with the message data. - Use JSON to safely package data in strings.
在你的代码中加入window.postMessage()
和window.addEventListener("message"...
,就变成了:
Adding window.postMessage ()
and window.addEventListener ("message"...
to your code, it becomes:
... ...
//-- Only run in the top page, not the various iframes.
if (window.top === window.self) {
var timeBtn = document.createElement ('a');
timeBtn.id = "gmTimeBtn";
timeBtn.textContent = "Time";
//-- Button is styled using CSS, in GM_addStyle, below.
document.body.appendChild (timeBtn);
addJS_Node (null, null, activateTimeButton);
window.addEventListener ("message", receiveTimeMessage, false);
}
function activateTimeButton () {
var timeBtn = document.getElementById ("gmTimeBtn");
if (timeBtn) {
timeBtn.addEventListener ('click',
function () {
var ytplayer = document.getElementById ("movie_player");
/*-- GM_functions will not work here, so send the data
back to the GM script scope.
*/
//-- Tag the message, we may not be the only ones sending.
var messageTxt = JSON.stringify (
{currentVidTime: ytplayer.getCurrentTime ()}
);
window.postMessage (messageTxt, "*");
},
false
);
}
else {
alert ("Time button not found!");
}
}
function receiveTimeMessage (event) {
var messageJSON;
try {
messageJSON = JSON.parse (event.data);
}
catch (zError) {
// Do nothing
}
if ( ! messageJSON || ! messageJSON.currentVidTime)
return; //-- Message is not for us.
/*--- We have a time value, set it with GM_setValue ()
But, WARNING: First make sure that the stored value is
a safe string. GM_setValue() crashes on just about anything else.
*/
var safeValue = JSON.stringify (messageJSON.currentVidTime);
GM_setValue ("videoMarkedTime", safeValue);
console.log ("Video time recorded with GM_setValue ().");
}
... ...
您可以通过打开 about:config
并搜索 videoMarkedTime
来查看存储的值.
You can see the stored value by opening about:config
and searching for videoMarkedTime
.
这篇关于如何从必须在目标页面范围内运行的代码中调用 Greasemonkey 的 GM_ 函数?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何从必须在目标页面范围内运行的代码中调用 Greasemonkey 的 GM_ 函数?
- Fetch API 如何获取响应体? 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- 400或500级别的HTTP响应 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01