BUG 描述
aHR0cHM6Ly9zdXBwb3J0Lmdvb2dsZS5jb20vY2hyb21lL2Fuc3dlci8xODY4NTA/dmlzaXRfaWQ9NjM4Mzc1MzExMTU2NTEwODcyLTIwOTg5NjA2NjMmcD1mZWVkYmFja19jb25maXJtYXRpb24mcmQ9MQ==
BUG 修复(2023-12-14 更新)
升级到 120.0.6099.71 + 版本后,BUG 已修复。
aHR0cHM6Ly9zdXBwb3J0Lmdvb2dsZS5jb20vY2hyb21lL2Fuc3dlci8xODY4NTA/dmlzaXRfaWQ9NjM4Mzc1MzExMTU2NTEwODcyLTIwOTg5NjA2NjMmcD1mZWVkYmFja19jb25maXJtYXRpb24mcmQ9MQ==
升级到 120.0.6099.71 + 版本后,BUG 已修复。
在给 Workflows 页面里面的 Chrome 书签,添加 快速使用示例代码 时,发现在 Arc 浏览器里面,无法正常使用,而在 Chrome 浏览器里面可以正常使用。
看看怎么区分一下 Arc 浏览器和 Chrome 浏览器,然后在 Arc 浏览器不给提示。
查看两个浏览器的 User Agent,一毛一样:
Arc 浏览器:
> navigator.userAgent
< 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36'
Chrome 浏览器:
> navigator.userAgent
< 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36'
搜索找到了这篇文章:Can JavaScript detect the Arc browser? – Stack Overflow。
根据这篇文章里面的提示,可以通过 获取 Arc 浏览器 的 User Agent Atylesheet(浏览器默认样式) 来区分 Arc 浏览器和 Chrome 浏览器。
:root {
--arc-palette-cutoutColor: #ECEDFEFF;
--arc-palette-backgroundExtra: #FDFDFFFF;
--arc-palette-minContrastColor: #ECEDFEFF;
--arc-palette-hover: #D3D4FDFF;
--arc-palette-background: #E9EAFEFF;
--arc-palette-focus: #9094FBFF;
--arc-palette-foregroundPrimary: #3139FBFF;
--arc-palette-maxContrastColor: #212AFBFF;
--arc-background-gradient-color0: #C8CAFEFF;
--arc-palette-subtitle: #A6AAFBFF;
--arc-palette-foregroundSecondary: #8489FBFF;
--arc-palette-foregroundTertiary: #ECEDFEFF;
--arc-background-gradient-color1: #FFE6E6FF;
--arc-palette-title: #0A0D4BFF;
}
只判断是否有值其中一个变量存在就可以了。
<script setup lang="ts">
import { onMounted, ref } from 'vue'
const isArcBrowser = ref(false);
onMounted(() => {
isArcBrowser.value = getComputedStyle(document.documentElement)
.getPropertyValue('--arc-palette-title') ? true : false;
console.log('isArcBrowser', isArcBrowser.value);
});
</script>
以下是一些常用的 Chrome 书签,使用步骤:
手动创建书签
快速使用示例代码
17.0 (19616.1.27.111.16)
)
TAPD 项目管理 计算花费工时
即可javascript: (function () {
var arr = [];
var totalTime = 0;
var trs = document.querySelectorAll('.g_table_autowidth tbody tr');
var name = document.querySelector('h3.name span').innerText;
for (let index = 0; index < trs.length; index++) {
let tr = trs[index];
let tds = tr.querySelectorAll('td');
if (tds.length === 8) {
tds[0].remove();
tds[1].remove();
tds[2].remove();
} else if (tds.length === 6) {
tds[0].remove();
}
}
var trs = document.querySelectorAll('.g_table_autowidth tbody tr');
for (let index2 = 0; index2 < trs.length; index2++) {
let tr = trs[index2];
let tds = tr.querySelectorAll('td');
if (!arr.length && tds[0].innerText) {
totalTime += Number(tds[1].innerText);
arr.push({
project: tds[0].innerText,
countTime: Number(tds[1].innerText)
});
} else if(arr.length && tds[0].innerText) {
var arrExistIndex = arr.findIndex((item) => item.project === tds[0].innerText);
if (arrExistIndex !== -1) {
totalTime += Number(tds[1].innerText);
arr[arrExistIndex].countTime += Number(tds[1].innerText);
} else {
totalTime += Number(tds[1].innerText);
arr.push({
project: tds[0].innerText,
countTime: Number(tds[1].innerText)
});
}
}
}
var str = '';
for (let index3 = 0; index3 < arr.length; index3++) {
var {project, countTime} = arr[index3];
var zanbi = (countTime/totalTime * 100).toFixed() / 100;
str += `${project}\t${countTime}\t${ zanbi ? `${name}${(Math.round(zanbi * 10) / 10)}` : '' }\n`;
}
str += ` \t${totalTime}`;
prompt("复制粘贴到 Excel 中", str);
})();
Yapi body 参数 转换为 JSDoc 注释
即可javascript: (function () {
function contains(selector, text) {
var elements = document.querySelectorAll(selector);
return Array.prototype.filter.call(elements, function(element){
return RegExp(text).test(element.textContent);
});
}
function capitalizeFirstLetter(string) {
return string.charAt(0).toUpperCase() + string.slice(1);
}
var trs1 = document.querySelector('.panel-view');
var apiName = trs1.querySelector('.row .colName').innerText;
var trs = contains('div', /^Body/)[0].querySelectorAll('.ant-table-tbody tr');
console.log('trs', trs)
var str = `/**\n * ${ apiName }\n`;
for (let index = 0; index < trs.length; index++) {
let tr = trs[index];
let tds = tr.querySelectorAll("td");
str += ` * @param {${ capitalizeFirstLetter(tds[1].innerText) }} data.${ tds[0].innerText } ${ tds[4].innerText }\n`;
}
str += ` * @url ${ window.location.href }\n * @returns Promise\n */`;
var x = document.createElement("DIALOG");
var t = document.createTextNode(str);
x.appendChild(t);
x.style = "white-space: pre;"
document.body.appendChild(x);
x.addEventListener('copy',function(e){
setTimeout(() => {
x.hidden = true;
x.remove();
}, 320);
});
x.showModal();
})();
批量删除 Snapmail.cc 单个邮箱内的邮件
即可javascript: (function () {
var lis = document.querySelectorAll('.email-container .sidebar-scrollable-content .email-list li[ng-repeat="item in filtered = (items | orderBy:\'time\':!reverse | filter: search) "]');
for (let index = 0; index < lis.length; index++) {
const emailId = lis[index].querySelector('a').getAttribute('href').split('#/email/')[1];
fetch(`https://www.snapmail.cc/email/${emailId}`, {
"headers": {
"accept": "application/json, text/plain, */*",
"accept-language": "zh-CN,zh-TW;q=0.9,zh;q=0.8,ja-JP;q=0.7,ja;q=0.6,en-US;q=0.5,en;q=0.4,ko-KR;q=0.3,ko;q=0.2",
"cache-control": "no-cache",
"pragma": "no-cache",
"sec-ch-ua": "\"Chromium\";v=\"116\", \"Not)A;Brand\";v=\"24\", \"Google Chrome\";v=\"116\"",
"sec-ch-ua-mobile": "?0",
"sec-ch-ua-platform": "\"macOS\"",
"sec-fetch-dest": "empty",
"sec-fetch-mode": "cors",
"sec-fetch-site": "same-origin"
},
"referrer": "https://www.snapmail.cc/",
"referrerPolicy": "strict-origin-when-cross-origin",
"body": null,
"method": "DELETE",
"mode": "cors",
"credentials": "include"
}).then(res => {
return res.json()
});
}
})();
公众号文章信息
即可javascript: (function () {
function getarticleInfo() {
let obj = {};
obj['title'] = msg_title || document.title;
obj['content'] = msg_desc || "";
obj['author'] = title || "";
obj['createTime'] = document.querySelector('#publish_time').innerText || new Date().getTime();
obj['image'] = msg_cdn_url || "";
obj['blankUrl'] = location.href;
return JSON.stringify(obj, null, 2);
}
setTimeout(() => {
navigator.clipboard.writeText(`${getarticleInfo()},`);
}, 320);
})();
结果内容:
{
"title": "主播说联播丨大胆闯、大胆试、自主改!",
"content": "",
"author": "央视新闻",
"createTime": "2023-09-26 22:47",
"image": "https://mmbiz.qpic.cn/sz_mmbiz_jpg/oq1PymRl9D6Ok0VQvMrI5flK4zRNtnQCKkXwibaq19DHGTCKjaneibGV9Dw7IRzIFDp8ru3ekovHuCE3xSsDPDuQ/0?wx_fmt=jpeg",
"blankUrl": "https://mp.weixin.qq.com/s/ppTuriLssKstpWL-yqe9HA"
},
公众号文章封面图
即可1:1
) 2、长方形(2.35:1
)javascript: (function () {
cdn_url_1_1 && window.open(cdn_url_1_1);
msg_cdn_url && window.open(msg_cdn_url);
})();
快速使用示例代码: 拖拽 ta 到 书签栏 👉 <a class="js-drag" href="javascript: (function () {
cdn_url_1_1 && window.open(cdn_url_1_1);
msg_cdn_url && window.open(msg_cdn_url);
})();">公众号文章封面图</a>
统计美团外卖订单金额大于30元的订单
即可javascript: (function () {
const lis = document.querySelectorAll('div[class^="orderList"] li')
const 订单列表 = [];
const 金额 = 30;
for (let index = 0; index < lis.length; index++) {
// console.log(lis[index].innerText)
var li = lis[index];
var 单个订单金额 = li.querySelector('.price_Ul_Wom').innerText.split('实付¥')[1] * 1;
if (单个订单金额*1 >= 金额) {
订单列表.push({
日期: li.querySelector('*[class^="time"]').innerText.split('\n')[0],
订单号: li.querySelector('div[class^="orderWrap"]').dataset.id.split('id')[1],
商家: li.querySelector('*[class^="name"]').innerText,
金额: li.querySelector('.price_Ul_Wom').innerText.split('实付¥')[1]
})
}
}
setTimeout(() => {
navigator.clipboard.writeText(`${JSON.stringify(订单列表.reverse(), null, 2)}`);
}, 320);
})();
结果内容:
[
{
"日期": "2023-01-01 00:00",
"订单号": "8888888888888888888",
"商家": "麦当劳&麦咖啡(北京西大望路店)",
"金额": "30.0"
}
]
小商家,订单满100,1000,统一开发票,需要统计订单
统计美团外卖在某个商家下的订单
即可javascript: (function () {
var lis = document.querySelectorAll('div[class^="orderList"] li')
const 订单列表 = []
const 商家 = '门框卤煮(双井店)';
for (let index = 0; index < lis.length; index++) {
// console.log(lis[index].innerText)
var li = lis[index]
if (商家 === li.querySelector('*[class^="name"]').innerText) {
订单列表.push({
日期: li.querySelector('*[class^="time"]').innerText.split('\n')[0],
订单号: li.querySelector('div[class^="orderWrap"]').dataset.id.split('id')[1],
金额: li.querySelector('.price_Ul_Wom').innerText.split('实付¥')[1]
})
}
}
setTimeout(() => {
navigator.clipboard.writeText(`${JSON.stringify(订单列表.reverse(), null, 2)}`);
}, 320);
})();
当前页面以窗口形式打开
540
800
javascript: (function () {
var defaultWidth = 540, defaultHeight = 800;
var openWindowWidth = window.prompt('窗口宽度(width)', defaultWidth);
var openWindowHeight = window.prompt('窗口高度(height)', defaultHeight);
var screenHeight = window.screen.height;
var screenWidth = window.screen.width;
var screenX = (screenHeight - openWindowHeight) / 2;
var screenY = (screenWidth - openWindowWidth) / 2;
var windowFeatures = 'height='+ openWindowHeight +', width=' + openWindowWidth + ', top=' + screenX + 'px, left=' + screenY + 'px, toolbar=no, menubar=no, scrollbars=no, resizable=no, location=no, status=no';
window.open(window.location.href, 'newwindow', windowFeatures);
})();
生成二维码
javascript: (function () {
var baseUrl = 'http://2.webclown.net/?';
var url = baseUrl + 'url=' + encodeURIComponent(location.href);
window.open(url);
})();
快速使用示例代码: 拖拽 ta 到 书签栏 👉 <a class="js-drag" href="javascript: (function () { var baseUrl = ‘http://2.webclown.net/?’; var url = baseUrl + ‘url=’ + encodeURIComponent(location.href); window.open(url); })();">生成二维码</a>
复制转载信息
javascript: (function () {
navigator.clipboard.writeText('[' + document.title + '](' + window.location.href + ')');
})();
快速使用示例代码: 拖拽 ta 到 书签栏 👉 <a class="js-drag" href="javascript: (function () { navigator.clipboard.writeText(‘[‘ + document.title + ‘](‘ + window.location.href + ‘)’);})();">复制转载信息</a>
生成短网址
javascript: !(function () {
var myHeaders = new Headers();
myHeaders.append("Content-Type", "application/json");
var raw = JSON.stringify({
longUrl: window.location.href,
});
var requestOptions = {
method: "POST",
headers: myHeaders,
body: raw,
redirect: "follow",
};
fetch("https://00s.top/api/shorten", requestOptions)
.then((response) => response.json())
.then((result) => {
if (result.shortUrl) {
const link = "https://00s.top/" + result.shortUrl;
const dialog = document.createElement("dialog");
dialog.innerHTML =
"<div class='position: fixed;top: 1em;right: 1em;background: #fff;'><p style='text-align: center; padding: 1em; background: #1d91eb; color: #fff;'>短网址已生成:(自动复制)</p><p style='padding: 1em;'>" +
link +
"</p></div>";
document.body.appendChild(dialog);
dialog.showModal();
navigator.clipboard.writeText('[' + document.title + '](' + link + ')');
setTimeout(() => dialog.close(), 2000);
}
})
.catch((error) => {
const dialog = document.createElement("dialog");
dialog.innerHTML =
"<div class='position: fixed;top: 1em;right: 1em;background: #fff;'><p style='text-align: center; padding: 1em; background: #1d91eb; color: #fff;'>生成失败</p><p style='padding: 1em;'>当前站点禁止使用书签脚本,请访问:https://00s.top 生成。</p><form method='dialog'><button>关闭</button></form></div>";
document.body.appendChild(dialog);
dialog.showModal();
});
})();
chrome://history
host:example.com
Command + A
Ctrl + A
详情查看:https://software.webclown.net/
以下是一个简单概要。
如何清除掉这些繁琐的历史记录呢:
clear();
console.clear();
Ctrl/control+L
然而执行完并没有什么用,历史记录还是会存在。
然后就去stackoverflow上面找到一个解决方案特简单:
从Chrome 50起,您可以从控制台上下文菜单中使用“Clear console history(清除控制台历史记录)”。
咦,上图怎么会有两个控制台呢:
1 打开控制台(command
+ option
+ i
),控制台右上角的三个点(Customize and control DevTools
\定制和控制DevTools)
2 光标定位到弹出来的控制台,然后按快捷键 command
+ option
+ i
定制和控制DevTools的DevTools。
3 恩,就酱紫,两个都出现了。
4 然后你找到 Application tab
-> Storage
-> Local Storage
-> chrome-devtools://devtools
-> consoleHistory
这个数组里面就是所有commandLine历史记录
搞定,玩的愉快🤣,Happy New Year!