Firefox 其实自带右键搜索选中文本的,但是有时候我本并不想用默认搜索引擎搜索技术内容(都是上简中互联网的,DDDD)

原来我是用 Selection Context Search 这个拓展的,但是忘记从哪个版本开始,只要一重启 Firefox,这个插件就丢配置,所以使用 addMenuPlus 替代它。

addMenuPlus 是一个非常强大的定制菜单的 uc 脚本。通过配置文件可添加、修改、隐藏菜单,修改后无需重启生效。ywzhaiqi 基于 Griever/addMenu.uc.js 修改增强我基于 ywzhaiqi 的 addMenuPlus 再次修复增强ywzhaiqi 新增的功能新增修改原有菜单的功能新增参数 %FAVICON_BASE64%:站点图标的 base64新增参数 %IMAGE_BASE64%:图片的 BASE64新增参数 %TITLES%:简短的标题我新增的功能新增属性新增参数 %SVG_BASE664%:SVG的 BASE64不过 ywzhaiqi 大佬已经不用 Firefox 很久了。我就简单修修脚本,搬运 README 并修正不能用的例子。使用说明及技巧_...

下面直接给出 addMenuPlus 配置

new function () {
    var items = [{
        id: 'addMenu-sitesearch-insertpoint',
        label: 'separator',
    }, {
        label: Services.locale.appLocaleAsBCP47.includes("zh-") ? '生成二维码' : 'Generate QR code',
        where: 'tab',
        url: "https://my.tv.sohu.com/user/a/wvideo/getQRCode.do?text=%s",
        image: ""
    }];
    var menu = PageMenu({
        id: 'addMenu-search-select',
        condition: 'select',
        image: "",
        accesskey: 'S',
        onshowing: function (e) {
            var sel = addMenu.convertText(Services.locale.appLocaleAsBCP47.includes("zh-") ? "搜索: %SEL%" : "Search %SEL% by");
            if (sel && sel.length > 15)
                sel = sel.substr(0, 15) + "...";
            this.label = sel;
            let popupNode = this.querySelector('menupopup');
            popupNode.querySelectorAll('.auto-generated').forEach(m => { m.parentNode.removeChild(m); })
            let ins = popupNode.firstChild;
            Services.search.getEngines().then(
                engines => engines.forEach((item) => {
                    let menuitem;
                    menuitem = addMenu.newMenuitem({
                        label: item._name,
                        class: "auto-generated",
                        where: 'tab',
                        text: "%s",
                        keyword: item._definedAliases[0]
                    });
                    ins.parentNode.insertBefore(menuitem, ins);
                }))
        },
    });
    menu(items);
    css("#context-searchselect { display: none } #contentAreaContextMenu #addMenu-search-select .menu-accel-container { visibility: hidden; }");
};