javascript - greasemonkey 插入 javascript

标签 javascript greasemonkey

我有一个小书签,单击小书签包括一个 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/

相关文章:

javascript - 如何在弹出窗口中制作十字关闭标志

javascript - 隐藏 stackoverflow 帖子的 Greasemonkey 脚本?

javascript - JavaFx WebView 视频 : onended event

javascript - Ractive 模板中的多个数据对象

javascript - 从 HTML5 本地存储中检索值

screenshot - 通过greasemonkey/scriptish/等捕获屏幕

javascript - 使用 Greasemonkey 修改所有链接

javascript - 如何制作 Greasemonkey 脚本来自动下载文件?

javascript - 使用 Greasemonkey 在 Div 下添加新链接

javascript - D3 实时流图(图形数据可视化)