我有一个小书签,单击小书签包括一个 PHP 脚本(评估为 JavaScript 文件)到页面的几个表值和选择值作为 GET 参数传递。 PHP 脚本将页面数据写入 MySQL 数据库,并输出一条成功消息,该消息被视为 JavaScript 代码并由浏览器执行。是否有可能使用 greasemonkey 执行此操作并在网页上单击现有按钮时调用此函数。
我在本教程的启发下编写了上述书签。
http://tutorialzine.com/2010/04/simple-bookmarking-app-php-javascript-mysql/
这是书签代码:
(function () {
var jsScript = document.createElement('script');
jsScript.setAttribute('type', 'text/javascript');
jsScript.setAttribute('src', '/bookmark.php?url=' + encodeURIComponent(location.href) + '&title=' + encodeURIComponent(document.title));
document.getElementsByTagName('head')[0].appendChild(jsScript);
})();
请帮帮我。
最佳答案
我们经常这样做。
这是一个适合您的脚本,只需编辑 @include
语句以匹配将使用 Greasemonkey 脚本的页面。
此外,/bookmark.php
可能必须更改为完整地址,而不是相对地址。
//
// ==UserScript==
// @name Adding a live button
// @namespace http://www.google.com/
// @description Adds a custom bookmarking button.
// @include http://www.google.com/*
// ==/UserScript==
//
function LocalMain ()
{
/*--- Create a button in a container div. It will be styled and postioned with CSS.
*/
var zNode = document.createElement ('div');
zNode.innerHTML = '<form id="idMyForm" method="get" action="">'
+ ' <p><input type="submit" id="idMySubmitBtn" value="Bookmark it"></p>'
+ '</form>'
;
zNode.setAttribute ('id', 'idBookMarkBtnContainer');
document.body.appendChild (zNode);
zNode.addEventListener ("submit", BookmarkButtonAction, false);
}
function BookmarkButtonAction (zEvent)
{
zEvent.preventDefault();
var jsScript = document.createElement('script');
jsScript.setAttribute('type', 'text/javascript');
/*--- Is "/bookmark.php" going to work on all target pages?
*/
jsScript.setAttribute('src', '/bookmark.php?url=' + encodeURIComponent(location.href) + '&title=' + encodeURIComponent(document.title));
document.getElementsByTagName('head')[0].appendChild(jsScript);
return false;
}
window.addEventListener ("load", LocalMain, false);
//LocalMain();
GM_addStyle
(
'#idBookMarkBtnContainer \
{ \
position: absolute; \
top: 0; \
left: 0; \
\
background: orange; \
border: 3px double #999999; \
margin: 5px; \
opacity: 0.9; \
z-index: 222; \
\
min-height: 10px; \
min-width: 20px; \
padding: 5px 20px; \
} \
#idMySubmitBtn \
{ \
cursor: pointer; \
} \
'
);
关于javascript - greasemonkey 插入 javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2898974/