1、如下所示为新建脚本时的默认内容,顶部的注释/注解表明了脚本的各个属性。
2、元数据块必须位于顶部 ==UserScript== 之间。
3、Greasy Fork 要读取的脚本元键值:https://greasyfork.org/zh-CN/help/meta-keys
// ==UserScript==
// @name New Userscript
// @namespace http://tampermonkey.net/
// @version 0.1
// @description try to take over the world!
// @author You
// @match https://mp.csdn.net/mp_blog/creation/editor/new?spm=1001.2101.3001.5352
// @icon https://www.google.com/s2/favicons?sz=64&domain=csdn.net
// @grant none
// ==/UserScript==
(function() {
'use strict';
// Your code here...
})();
属性名 | 作用 |
@name | 油猴脚本名称,会展示到浏览器中。必填项。 |
@namespace | 脚本命名空间,用于唯一确定脚本。油猴管理面包中点击主页按钮即可跳转到此地址。 |
@homepage | 主页地址。油猴管理面包中点击主页按钮即可跳转到此地址。可以作为脚本更新网址。 |
@version | 脚本版本,用于脚本的更新。必填项。 |
@icon | 用于指定脚本图标,可以设置为图片 URL 地址或 base64 的字符串 |
@description | 脚本描述。必填项。 |
@author | 作者名字 |
@license | 脚本所使用的许可协议名称或地址,该协议需包含用户是否允许二次分发 或修改 脚本的权利。 其它人都可以随意使用时,指定为 MIT 即可。 |
@match | 使用通配符匹配需要运行网址,例如 * 、 http://* 、 http://www.baidu.com/*等。 |
@exclude | 排除匹配到的网站。 |
@include | 保护匹配到的网站。 |
@run-at | 指定脚本的运行时机,如 页面加载完成时执行:@run-at document-end |
@grant | 指定脚本运行所需权限,拥有相应的权限才能调用油猴扩展提供的与浏览器进行交互的API。如果为 none,则不使用沙箱环境,脚本会直接运行在网页的环境中,这时无法使用大部分油猴扩展的 Api,而只能使用油猴默认添加的几个最常用 Api。 |
@require | 指定脚本依赖的其他js库,比如 JQuery。 |
@connect | 用于跨域访问时指定的目标网站域名。 当用户使用 gm_xmlhttprequest 请求远程数据的时候,需要使用connect指定允许访问的域名,支持域名、子域名、ip地址以及 * 通配符 |
@updateURL @installURL @downloadURL |
脚本更新网址,当油猴扩展检查更新的时候,会尝试从这个网址下载脚本,然后比对版本号确认是否更新,不写时,@homepage也可以代替。 |
@supportURL | 用户可获得该脚本技术支持的链接地址 (如:错误反馈系统、论坛、电子 邮件),该链接将显示在脚本的反馈页面。 |
@contributionURL | 用于捐赠脚本作者的链接,该链接将显示在脚本的反馈页面。 |
@contributionAmount | 建议捐赠金额,请配合 @contributionURL 使用。 |
1、@grant 常用的权限,注意其中的前缀 GM 必须大写。
权限名 | 功能 |
@grant unsafewindow | 允许脚本可以完整访问原始页面,包括原始页面的脚本和变量。 |
@grant GM_getValue //GM_getValue(name,defaultvalue) |
从油猴扩展的存储中访问指定key的数据。可以设置默认值,在没成功获取到数据的时候当做初始值。如果保存的是日期等类型的话,取出来的数据会变成文本,需要自己转换一下。 |
@grant GM_setValue | 将数据保存到油猴扩展的存储中:GM_setValue(name,value)。 即使关了浏览器,重新打开仍然能获取到值。 同一个值在匹配的全部网页中都能获取到,所以必须在属性名中加以区分。 |
@grant GM_deleteValue | 将数据从油猴扩展的存储中删除:GM_deleteValue(name) |
@grant GM_listValues | 从油猴扩展的存储中访问全部数据。 |
@grant GM_addValueChangeListener | 添加对 gm_setvalue 的值进行监听,当值发生变化时,调用方法事件。 // 添加一个监听器 const listener_id = GM_addValueChangeListener('hello',function(name, old_value, new_value, remote){ // 方法回调 }); |
@grant GM_removeValueChangeListener | 移除对 GM_setvalue 的值进行监听:GM_removeValueChangeListener(listener_id) |
@grant GM_xmlhttprequest | 异步请求数据。 GM_xmlhttpRequest({ url: "http://www.httpbin.org/post", method: 'POST', headers: { "content-type": "application/json" }, data: {xxx}, onerror: function(res){ console.log(res); }, onload: function(res){ console.log(res); } }); |
@grant GM_setclipboard // GM_setclipboard(data, info) |
将数据复制到剪贴板中,第一个参数是要复制的数据,第二个参数是mime类型,用于指定复制的数据类型。 |
@grant GM_log | 用于在控制台中打印日志,便于调试: GM_log("Hello World") 也可以使用原生的 console.log(xxx); 打印日志。 |
@grant GM_addStyle | 向网页中指定元素(可以通过标签名,class样式,ID等选择)添加样式:GM_addStyle(css) 示例一:GM_addStyle("#main_nav,.title_box-WbZs0QZH{display:none !important}"); a、向指定id的元素,以及含有指定样式的元素添加css样式。 b、多个选择器时用逗号隔开,多个style样式属性时用分号隔开。 c、每一个css属性后面要跟一个 !important,表示添加的属性权限。 示例二:* 表示选择所有元素,如 GM_addStyle("* {margin-top:0px !important; margin-left:0px !important}"); 示例三:GM_addStyle("div .logo {background-image: url('http://xxxxxx.jpg') !important}"); a、为含有 .logo 样式的 div 元素设置背景图片(中间的空格表示层级)。 示例四:向页面添加自定义样式属性,然后使用 JQuery 的 hasClass、addClass、removeClass、toggleClass 方法操作目标元素的样式。 GM_addStyle(".myClass {border: 3px dotted green;background-color: red;}"); $("#main_nav").addClass("myClass"); 示例五:将含有指定属性的div元素设置为不可见。 GM_addStyle("div[align='center'],div[class='nav_bar wrap'] {display:none !important}"); |
@grant GM_notification | 设置网页通知/提示。 GM_notification(details, ondone) GM_notification(text, title, image, onclick) |
@grant window.close | |
@grant window.focus | |
// @grant GM_registerMenuCommand 注册菜单命令,浏览器油猴插件展示脚本名称时,会携带此菜单,方便用户做一些设置,而不用手动修改脚本。 |
function switchLanguage(){ // 函数内容 } GM_registerMenuCommand("语言切换", switchLanguage); GM_registerMenuCommand("自定义設置", () => { window.open("https://xxx.xxx.xxx/xxx", "_blank"); }); |
@grant GM_openInTab // GM_openInTab(url, options) |
打开一个新的标签页面,类似 windown.open(url)。 url:指定打开的新 URL 地址; options:指定页面展示方式及焦点停留页面。 GM_openInTab("https://www.baidu.com",{ active: true, setParent :true}); // active:true,新标签页获取页面焦点 // setParent :true:新标签页面关闭后,焦点重新回到源页面 |
1、浏览微博视频时,自动在视频上边展示【下载】按钮,点击按钮即可下载对应的视频,方便快捷。
2、greasyfork.org/zh-CN/scripts/458716-微博视频下载助手。
https://greasyfork.org/zh-CN/scripts/459871-华为云工作项列表突出展示工作项。
// ==UserScript==
// @name 潜入底部
// @namespace https://greasyfork.org/zh-CN/scripts/483583-%E6%BD%9C%E5%85%A5%E5%BA%95%E9%83%A8
// @version 1.2
// @description 某些网站舍弃了传统的数字分页方式,而是采用滚动条向下滚动自动翻页,而当页数很多时,手动滚动非常麻烦,所以此脚本让它自动滚动。
// @author 蚩尤后裔
// @homepage https://greasyfork.org/zh-CN/scripts/483583-%E6%BD%9C%E5%85%A5%E5%BA%95%E9%83%A8
// @match http*://*/*
// @require http://libs.baidu.com/jquery/2.0.0/jquery.min.js
// @require https://cdn.bootcdn.net/ajax/libs/artDialog/7.0.0/dialog.js
// @grant GM_registerMenuCommand
// @license MIT
// @downloadURL https://update.greasyfork.org/scripts/483583/%E6%BD%9C%E5%85%A5%E5%BA%95%E9%83%A8.user.js
// @updateURL https://update.greasyfork.org/scripts/483583/%E6%BD%9C%E5%85%A5%E5%BA%95%E9%83%A8.meta.js
// ==/UserScript==
// 将本内容直接复制粘贴到油猴中即可使用.
(function () {
'use strict';
let v_timer_interval = 500; // 间隔多少时间(毫秒)向下滚动一次
let v_pre_scrollTop = -1; // 上一次滚动条距离顶部的高度
let v_count_tatol = 5; // 滚动条距离顶部的高度在连续 v_count 都没有再发生变化时,停止继续向下滚动.
let v_count = 0; // 次数统计,当值达到 v_count_tatol 时,将停止滚动
$(function () {
// 向原始页面添加倒计时元素
appendCountDownEle('flex-end');
// 自定义功能菜单
GM_registerMenuCommand("开始下潜", customSetting);
});
/**
* 滚动条向底部运动翻页
* timer01 :是定时调用自己的定时器,用于停止
*/
function toBottom(timer01) {
/**
* scrollTop:div 滚动条距离 div 上边缘的距离
* scrollHeight:div 内文档总高度(包括被隐藏的),当没有出现滚动条时,scrollHeight = height
* height:div 元素的高度,只与自己 height 属性有关,与滚动条无关
*/
let scrollTop = $("html").scrollTop();
let scrollHeight = $("html")[0].scrollHeight;
let height = $("html").height();
// 设置滚动条距离顶部的高度
$("html").animate({
scrollTop: scrollHeight
}, v_timer_interval);
// console.log("============ height=" + height, "scrollTop=" + scrollTop, "scrollHeight=" + scrollHeight);
if (v_pre_scrollTop != scrollTop) {
v_pre_scrollTop = scrollTop;
v_count = 0;
$('#wmx_countdown_msg_div').text(scrollTop);
} else {
$('#wmx_countdown_msg_div').text(v_count_tatol - v_count);
v_count++;
}
// console.log("===================== v_count_tatol=" + v_count_tatol + ", v_count=" + v_count + ", v_pre_scrollTop=" + v_pre_scrollTop);
if (v_count >= v_count_tatol) {
// console.log("============ 连续 " + v_count + " 次,内容都没有变化,不再继续向下滚动。");
clearInterval(timer01);
// 清空提示内容并进行隐藏
$('#wmx_countdown_msg_div').text('已经到达底部啦');
$('#wmx_countdown_msg_div').hide(5000);
}
}
/**
* 自定义设置菜单功能
*/
function customSetting() {
// 如果已经弹出了,则直接跳过,不再重复弹出
if ($("#wmx_dialog_div").length > 0) {
return;
}
let contentHtml = "<div id='wmx_dialog_div'><p>是否开始向下潜到底部?<p/></div>";
let wmx_dialog = dialog({
title: '提示',
// quickClose: true, // 点击空白处快速关闭
fixed: true,
content: contentHtml,
okValue: '确定',
ok: function () {
// 清空提示内容并进行展示
$('#wmx_countdown_msg_div').text('');
$('#wmx_countdown_msg_div').show();
let timer01 = setInterval(() => {
toBottom(timer01);
}, v_timer_interval);
},
cancelValue: '取消',
cancel: function () {}
});
// 弹框
wmx_dialog.showModal();
}
/**
* 向原始页面添加倒计时元素
*
* @param align_items :对齐方式
* * align-items: flex-start; 上对齐
* * align-items: center; 中对齐
* * align-items: flex-end; 下对齐
*/
function appendCountDownEle(msg) {
let contDownJQ = $(`<div id="wmx_countdown_msg_div">Test</div>`);
contDownJQ.css({
'position': 'fixed',
'top': 0,
'bottom': 0,
'left': 0,
'right': 0,
'display': 'flex'
});
contDownJQ.css({
'justify-content': 'center',
'align-items': 'flex-end'
});
contDownJQ.css({
'color': 'rgba(252,85,49, 0.5)',
'font-size': '5vw'
});
contDownJQ.css({
'pointer-events': 'none',
'z-index': '9999'
});
// 默认隐藏
contDownJQ.hide();
$('body').append(contDownJQ);
}
})();