原理很简单,通过 websocket 通信 https://github.com/inu1255/debugirl
简单写了个服务端,可以获取 V2EX 的用户名。 可以看到跟写 chrome 插件的体验基本一致。
async function start() {
let tabs = await chrome.tabs.query({
url: "https://www.v2ex.com/",
});
let tab = tabs[0];
if (!tab) {
tab = await chrome.tabs.create({
url: "https://www.v2ex.com/",
index: 0,
active: false,
});
}
if (tab.status != "complete") await waitComplete(tab);
let name = await chrome.scripting.executeScript({
target: {tabId: tab.id},
func: function () {
return document.querySelector(".bigger").innerText;
},
});
console.log("your V2EX username is:", name);
}
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.