您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Adds a button to download video from a tweet
当前为
// ==UserScript== // @name Twitter Video Download // @namespace http://tampermonkey.net/ // @version 0.6 // @description Adds a button to download video from a tweet // @run-at document-idle // @author naileD // @include https://twitter.com/* // @include https://mobile.twitter.com/* // @icon https://www.google.com/s2/favicons?domain=twitter.com // @grant none // @license Unlicense // ==/UserScript== 'use strict'; setInterval(() => { var main = document.querySelector("main[role='main'] section[role='region']"); if (!main) return; var react = Object.entries(main.parentElement.parentElement).find(el => el[0].startsWith("__reactInternalInstance"))[1]; if (!react.memoizedProps.children[0]) return; var tweet = react.memoizedProps.children[0]._owner.memoizedProps.focalTweet; if (!tweet || !tweet.extended_entities || !tweet.extended_entities.media || !tweet.extended_entities.media[0].video_info) return; var el = document.querySelector(`a[href*="${tweet.id_str}"]`); if (!el) return; while (el.tagName !== "ARTICLE") { el = el.parentElement; } el = el.querySelector(`[aria-label^="Share Tweet"`); if (!el) return; var el2 = el.parentElement.parentElement; if (el2.lastElementChild.tagName === "A") return; var video = tweet.extended_entities.media[0].video_info.variants.filter(v => v.content_type == "video/mp4").sort((a,b) => b.bitrate - a.bitrate)[0].url.replace(new RegExp("\\?tag=.*"), ""); var color = el.firstElementChild.style.color || document.querySelector("#react-root [aria-label^=Skip]").style.borderColor; var svg = `<svg width="22.5" height="22.5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="square" stroke-linejoin="arcs"> <g><path d="M18 14v5a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8c0-1.1.9-2 2-2h5M15 3h6v6M10 14L20.2 3.8"/></g></svg>`; el2.insertAdjacentHTML("beforeend", `<a href="${video}" target="_blank" style="display: flex; place-self: center; color: ${color};" title="Download Video">${svg}</a>`); }, 1000);