Yel*_*Guy 7 javascript dom settimeout console.log
我正在尝试删除 Twitter 页面上 JS 控制台中的推文。如果我通过选择按钮然后单击来手动执行此操作,我可以手动运行 3 个不同的功能。
const delButton=()=>{
document.querySelectorAll('[data-testid="caret"]')[0].click()
};
const clickDel=()=>{
document.querySelector("#layers > div.css-1dbjc4n.r-1d2f490.r-105ug2t.r-u8s1d.r-zchlnj.r-ipm5af > div > div > div > div:nth-child(2) > div.css-1dbjc4n.r-yfoy6g.r-z2wwpe.r-xnswec.r-1ekmkwe.r-1udh08x.r-u8s1d > div > div > div > div:nth-child(1) > div.css-1dbjc4n.r-16y2uox.r-1wbh5a2 > div > span");
};
const confirmDel=()=>{
document.querySelector("#layers > div:nth-child(2) > div > div > div > div > div > div.css-1dbjc4n.r-1awozwy.r-1kihuf0.r-18u37iz.r-1pi2tsx.r-1777fci.r-1pjcn9w.r-fxte16.r-1xcajam.r-ipm5af.r-9dcw1g > div.css-1dbjc4n.r-1awozwy.r-yfoy6g.r-1867qdf.r-1jgb5lz.r-pm9dpa.r-1ye8kvj.r-1rnoaur.r-d9fdf6.r-1sxzll1.r-13qz1uu > div.css-1dbjc4n.r-18u37iz.r-13qz1uu > div.css-18t94o4.css-1dbjc4n.r-1dgebii.r-42olwf.r-sdzlij.r-1phboty.r-rs99b7.r-16y2uox.r-1w2pmg.r-1vuscfd.r-1dhvaqw.r-1ny4l3l.r-1fneopy.r-o7ynqc.r-6416eg.r-lrvibr > div > span > span").click()
}
delButton();
clickDel();
confirmDel();
Run Code Online (Sandbox Code Playgroud)
我尝试了几种不同的方法,如果我通过在控制台中运行每个函数来手动运行它们,它就会起作用。然而,当我尝试将它们放入运行所有 3 个函数的函数中时,第二个函数不会单击,因为它尚未准备好。我在触发它们之前尝试使用 setTimeout 但它仍然不起作用。我也尝试过使用异步和等待,但我认为我对这个问题的理解是有限的。
const runEmAll=()=>{
setTimeout(delButton(), 1000);
setTimeout(clickDel(), 1000);
setTimeout(confirmDel(), 1000);
}
runEmAll();
// or I also tried...
const runDel = async ()=>{
await delButton();
}
runDel().then(clickDel());
Run Code Online (Sandbox Code Playgroud)
再次那不起作用..我得到的错误是
VM1649:2 Uncaught TypeError: Cannot read property 'click' of null
Run Code Online (Sandbox Code Playgroud)
参考clickDel函数
Uza*_*zay 17
。打开 Chrome 或任何浏览器。
(如果浏览器不是 Chrome,点击顺序和按钮可能会有所不同)。
。打开推特。
。单击个人资料或单击推文和回复
。按 F12(开发者选项)
。单击控制台选项卡
。粘贴此代码(推特语言必须是英语)
var delTweets = function () {
var tweetsRemaining =
document.querySelectorAll('[role="heading"]+div')[1].textContent;
console.log('Remaining: ', tweetsRemaining);
window.scrollBy(0, 10000);
document.querySelectorAll('[aria-label="More"]').forEach(function
(v, i, a) {
v.click();
document.querySelectorAll('span').forEach(function (v2, i2, a2) {
if (v2.textContent === 'Delete') {
v2.click();
document.querySelectorAll('[data-testid="confirmationSheetConfirm"]').forEach(function (v3, i3, a3) {
v3.click();
});
}
else {
document.body.click();
}
});
});
setTimeout(delTweets, 4000); //less than 4000 might be rate limited or account suspended. increase timeout if any suspend or rate limit happens
}
delTweets();
Run Code Online (Sandbox Code Playgroud)
我正在使用 Uzay 的解决方案,但它停止工作。这是我的解决方案,它也删除了转发。
要使用它,请转到 Twitter 时间线,然后转到“推文”选项卡删除所有推文,或者转到“回复”选项卡删除回复。
将以下代码粘贴到浏览器 JavaScript 控制台中。
确保在粘贴代码之前在代码中设置了您的 Twitter 句柄!
脚本 1:- 删除所有推文
// TO DELETE TWEETS MUST BE RUN FROM https://twitter.com/{yourTwitterHandle}
// TO DELETE REPLIES MUST BE RUN FROM https://twitter.com/{yourTwitterHandle}/with_replies
// IMPORTANT IMPORTANT IMPORTANT - SET YOUR TWITTER HANDLE IN THE NEXT LINE!
// IMPORTANT IMPORTANT IMPORTANT - SET YOUR TWITTER HANDLE IN THE NEXT LINE!
const yourTwitterHandle = "@yourhandle";
// one every 10 seconds to avoid Twitter noticing
const waitTimeSeconds = 10
const sleep = async (seconds) => new Promise(resolve => setTimeout(resolve, seconds * 1000));
const main = async () => {
while (true) {
await walkTweets();
await sleep(waitTimeSeconds)
}
}
const walkTweets = async () => {
let articles = document.getElementsByTagName('article');
for (article of articles) {
const spanElements = article.querySelectorAll('span');
for (spanElement of spanElements) {
// delete if it is a retweet
if (spanElement.textContent === "You reposted") {
article.scrollIntoView();
try {
const retweetElement = article.querySelector('[data-testid="unretweet"]');
if (retweetElement) {
retweetElement.click();
document.querySelector('[data-testid="unretweetConfirm"]').click();
}
} catch (e) {}
return
}
if (spanElement.textContent === yourTwitterHandle) {
// in this case it might be a tweet or a reply
article.scrollIntoView();
try {
// try to delete a reply
const tweetReplyElement = article.querySelectorAll('[aria-label="More"]')[1];
if (tweetReplyElement) {
tweetReplyElement.click()
Array.from(document.getElementsByTagName('*')).find(el => el.textContent.trim() === 'Delete').click()
document.querySelector('[data-testid="confirmationSheetConfirm"]').click();
return
}
} catch (e) {}
try {
// try to delete a tweet
const tweetElement = article.querySelector('[aria-label="More"]');
if (tweetElement) {
article.scrollIntoView();
tweetElement.click()
Array.from(document.getElementsByTagName('*')).find(el => el.textContent.trim() === 'Delete').click()
document.querySelector('[data-testid="confirmationSheetConfirm"]').click();
return
}
} catch (e) {}
}
}
}
}
main()
Run Code Online (Sandbox Code Playgroud)
脚本 2: - 删除所有点赞
// MUST BE RUN FROM https://twitter.com/{yourTwitterHandle}/likes
// one every 10 seconds to avoid Twitter noticing
const waitTimeSeconds = 2;
const maxRetries = 3;
const sleep = async (seconds) => new Promise(resolve => setTimeout(resolve, seconds * 1000));
const unlikeAllTweets = async () => {
let counter = 0;
let retryCount = 0;
while (true) {
try {
await sleep(waitTimeSeconds);
const element = document.querySelector('[data-testid="unlike"]');
if (element === null) {
if (retryCount >= maxRetries) {
console.log('element was null, no more likes found after retries, finished');
return;
}
console.log(`element was null, retrying... (${retryCount + 1}/${maxRetries})`);
retryCount++;
continue;
}
element.scrollIntoView();
element.click();
counter++;
retryCount = 0;
console.log(`Unliked a tweet. Total so far: ${counter}`);
await sleep(0.5);
// Remove the element's parent from the DOM to avoid it clagging up
if (element.parentElement) {
element.parentElement.remove();
}
} catch (error) {
console.error('An error occurred:', error);
}
}
};
unlikeAllTweets();
Run Code Online (Sandbox Code Playgroud)
添加 Mazen Alhrazi 答案(谢谢!),于 2022 年 12 月 21 日测试,此方法有效:
(async () => {
function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
let found;
while (found = document.querySelectorAll('[data-testid="caret"]').length) {
// get first tweet
let tweet = document.querySelectorAll('[data-testid="tweet"]')[0];
// if it is a retweet, undo it
if (tweet.querySelectorAll('[data-testid="unretweet"]').length) {
tweet.querySelectorAll('[data-testid="unretweet"]')[0].click()
await sleep(1000)
document.querySelectorAll('[data-testid="unretweetConfirm"]')[0].click()
await sleep(1000)
}
// is a tweet
else {
if (new Date(document.querySelectorAll('[datetime]')[0].getAttribute('datetime')) < new Date('2018')) {
console.log('Limit date reach')
break;
}
tweet.querySelectorAll('[data-testid="caret"]')[0].click()
await sleep(1000)
document.querySelectorAll('[role="menuitem"]')[0].click()
await sleep(1000)
document.querySelectorAll('[data-testid="confirmationSheetConfirm"]')[0].click()
}
}
if (!found)
console.log('No more tweets found');
})();
Run Code Online (Sandbox Code Playgroud)
我的主要问题是转发位于您自己的推文中间,因此您必须删除两者:根据类型取消转发和删除。
我添加了一个过滤器,这样您就不会删除早于 a 的推文Date(示例中为 2018 年)。if如果不需要,请编辑或删除它。
它并不完美,在一些对话/回复中存在一些问题,但它对我有用。也许其他人会解决这个问题:)
| 归档时间: |
|
| 查看次数: |
14696 次 |
| 最近记录: |