知乎剪贴板的小细节
2023-04-18 14:39:20 时间
今天发现知乎的剪贴板运用的非常好,粘贴图片的话会上传,这个在很多地方已经有了,如果是粘贴的是一个链接,知乎还会将链接自动的替换为链接的标题,下面是知乎的一段js:
handlePastedText: function (e, n, r) {
var i = r.getEditorState,
o = r.setEditorState;
if (n || !p.test(e))
return "not-handled";
var s = "//www.zhihu.com";
return "www2.zhihu.com" === location.host && (s = s.replace("www.zhihu.com", "www2.zhihu.com")),
t(function () {
return fetch(s + "/scraper", {
method: "POST",
body: "url=" + encodeURIComponent(e),
headers: {
"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8"
},
credentials: "include"
})
}).then(function (e) {
return e.json()
}).then(function (t) {
var n = t.title,
r = i(),
s = r.getCurrentContent(),
u = r.getSelection(),
l = void 0;
if (n && n !== e) {
var c = a.Entity.create("link", "MUTABLE", {
url: e
});
l = a.Modifier.replaceText(s, u, n, null, c)
} else
l = a.Modifier.replaceText(s, u, e);
var p = a.EditorState.push(r, l, "insert-link");
p && o(p)
}, function () {
var t = i(),
n = t.getCurrentContent(),
r = t.getSelection(),
s = a.Modifier.replaceText(n, r, e),
u = a.EditorState.push(t, s, "insert-characters");
u && o(u)
}),
"handled"
}
原理大概就是发送了一个url给后台,让后台获取链接的标题,然后返回给前台做处理替换链接文本为标题,在发现这段代码的过程中,我又无意中发现了一个chrome 的牛逼之处,就是对于压缩过的js代码chrome可以点击{}
这样的一个按钮格式化显示出来,之前一直都没有发现有这个功能。
格式化之前:
格式化之后:
相关文章
- 【技术种草】cdn+轻量服务器+hugo=让博客“云原生”一下
- CLB运维&运营最佳实践 ---访问日志大洞察
- vnc方式登陆服务器
- 轻松学排序算法:眼睛直观感受几种常用排序算法
- 十二个经典的大数据项目
- 为什么使用 CDN 内容分发网络?
- 大数据——大数据默认端口号列表
- Weld 1.1.5.Final,JSR-299 的框架
- JavaFX 2012:彻底开源
- 提升as3程序性能的十大要点
- 通过凸面几何学进行独立于边际的在线多类学习
- 利用行动影响的规律性和部分已知的模型进行离线强化学习
- ModelLight:基于模型的交通信号控制的元强化学习
- 浅谈Visual Source Safe项目分支
- 基于先验知识的递归卡尔曼滤波的代理人联合状态和输入估计
- 结合网络结构和非线性恢复来提高声誉评估的性能
- 最佳实践丨云开发CloudBase多环境管理实践
- TimeVAE:用于生成多变量时间序列的变异自动编码器
- 具有线性阈值激活的神经网络:结构和算法
- 内网渗透之横向移动 -- 从域外向域内进行密码喷洒攻击