【折腾】GM_脚本“取回” Feedly 内的订阅源地址

吐槽/反馈/建议:我的咸鱼心  爱发电-@wdssmq

虚拟桌面的快捷键仍然绝赞记不住 ing

相关文章:20210227485

Todo:如何在 Hexo 的博文中引用自己的文章 | 晨星的个人博客 ←←

以及,mdlint 插件要求英文和中文之间要有空格,所以也是略纠结;

需求描述

Feedly 中查看已订阅项目时,地址栏显示是这样:

https://feedly.com/i/subscription/feed%2Fhttps%3A%2F%2Ffeed.wdssmq.com

https://feedly.com/i/subscription/feed%2Fhttps%3A%2F%2Fwww.wdssmq.com%2Ffeed.php

「订阅源地址」部分是转码过的,虽然对于比较短的地址还是可以直接人肉识别出来,另外,在「···More settings」中也是可以看到源地址回显的。。

吐槽:
【果然从博客建议之初就是「不想配图」星人,,,即使改用「Markdown + 免费图床」后也没能提升多少;

【Feedly 这个回显也是过了很久才半途加上的。。

但是,对于某些出问题的订阅源,会提示下边信息然后不给你查看源地址的选项:

<div id="feedlyPageFX" class="container centered">
  <h2 class="Heading Heading--h2">
    Feed not found
    <div class="sub">Wrong feed URL or dead feed</div>
  </h2>
</div>

作为「GM_脚本」狂魔果然还是决定自己解决这个痛点顺便水一篇文章;

代码实现及讲解

  • 需要这样“取回”订阅源的频度还是略低的,所以设置为点击触发就好;
  • 因为 Feedly 使用的是前端渲染机制,上边提示对应的 html 在「源码查看」中其实并不存在,也就是属于「未来元素」,所以「监听事件」需要设置在会包含该「未来元素」的现存的元素节点上,本例中就是body#box
<body id="box" class="home">
…………
</body>
  • 监听事件:点击、按下、弹起, 这里都可以,代码中选用了mouseup
  • 当有错误提示的元素被点击时,执行后续操作,主要有三步:
    • 从当前地址中拿到订阅源的部分;
    • 解码;
    • 输出到页面;
  • ↑前两步顺序可以互换;
  • 输出到页面时使用了element.insertAdjacentHTML - Web API 接口参考 | MDN,类似 JQuery 中的.append()方法;
  • 具体输出到哪个元素中要也要分析和尝试,然后视情况使用上现有的样式类;
(function () {
  "use strict";
  function $n(e) {
    return document.querySelector(e);
  }
  function $na(e) {
    return document.querySelectorAll(e);
  }
  function addEvent(element, evnt, funct) {
    return element.addEventListener(evnt, funct, false);
  }
  // 拿回订阅源地址
  // 绑定监听事件到 div#box 上
  addEvent($n("#box"), "mouseup", function (event) {
    // 输出触发事件的元素
    console.log(event.target);
    // 根据内容判断是否执行相应操作
    const elText = event.target.innerHTML;
    if (
      // elText.indexOf("Feed not found") > -1 ||
      elText.indexOf("Wrong feed URL") > -1 // 保证提示信息中的两行都能触发
    ) {
      // 内部再输出一次确定判断条件正确
      console.log(event.target);
      // 拿到解码后的订阅源地址
      const curUrl = ((url) => {
        return url.replace("https://feedly.com/i/subscription/feed/", "");
      })(decodeURIComponent(location.href));
      // 输出到页面中
      $n("#feedlyPageFX h2").insertAdjacentHTML(
        "beforeend",
        `<div class="sub">${curUrl}</div>`
      );
    }
  });
})();

结束

自用 Feedly 完整脚本地址见:

// ----------------------------
// @raw    https://github.com/wdssmq/userscript/tree/master/feedly
// @raw    https://greasyfork.org/zh-CN/scripts/381793
// ----------------------------
// @link   https://afdian.com/@wdssmq
// @link   https://github.com/wdssmq/userscript
// @link   https://greasyfork.org/zh-CN/users/6865-wdssmq
// ----------------------------

另一篇相关文章:20100222433


爱发电

本文标题:《【折腾】GM_脚本“取回” Feedly 内的订阅源地址》作者:沉冰浮水
原文链接:https://www.wdssmq.com/post/20210305305.html
特别注明外均为原创,转载请注明。

分享到微信

扫描二维码

可在微信查看或分享至朋友圈。

相关文章

感谢分享 碉堡 回复
这个我似乎看过,感叹这些廉价劳动力
回复
阿门 阿门 发布于 2010-09-20 10:47:40  
#cmt2339

————
回访
回复
clyee clyee 发布于 2010-09-19 23:19:45  
#cmt2338
比机器还快
回复
囧啊囧 囧啊囧 发布于 2010-09-19 16:12:32  
#cmt2337
应该有童工在里面吧!银行职员其实也挺牛的。
回复
沉冰浮水 沉冰浮水 发布于 2010-09-18 21:11:50  
https://www.wdssmq.com
会出现这样的牛人就肯定是没有了。。至少这个厂子没有。。而这个应该是中国工厂的一个写照。。
----------
笑话不需要分类,只需要全文订阅
回复
微奇生活 微奇生活 发布于 2010-09-18 18:48:18  
#cmt2335
太强悍啦,我在药厂做过包装工,那个手叫疼啊
回复
访客 访客 发布于 2010-09-18 16:27:04  
#cmt2334
再过3天就是中秋节了,我在这里祝福您和您的家人中秋节快乐!
回复
长弓小k 长弓小k 发布于 2010-09-18 15:52:04  
#cmt2333
我.....................x
震精了
回复
这速度。难道没有机械化的设备来装么。。
回复
发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

网站分类

  • 订阅本站的 RSS 2.0 新闻聚合

搜索

本周旧文

nuc 四个口插硬盘都识别不到,有亮灯。。最后试出别插到底。。

绿联的硬盘盒。。另外一个联想的没问题。。

近期观影记录:超级马里奥,死侍与金刚狼。。

搬家也告一段落,虽然搬过来的东西还得归置,新衣柜虽说已经散俩月味儿了,但还是不想放衣服进去。

要不我每年汇总整理一次??碎雨集_沉冰浮水_第1页

所以,不带这条的话,2024 年目前只发了 13 条嘟????

VSCode 内 git 操作卡住的时候没办法主动取消一直是个痛点,一般都是推送或拉取,今天连提交都卡了。。

又一个夏天过去了,所以今年也没买防水鞋套;然后天凉了,为了应对踢被子买了睡袋,不知道 1.2 米会不会略窄。。

《五至七时的克莱奥》,2018 年 6 月加入列表,21 年 11 月底发现 B 站上线了这部,直到前几天才看完,还是分两次看的。。接下来有五项是 2019 年的,都是电影 —— 略长的待办列表。。

有用程序自动抓取自己带 tag 的嘟,然后按年备份后从线上删除;刚发现去年的数据有备份但是没删线上??和本地数据对比后发现线上的还少一条,Why??

本质上,每个人需要的是「让自己面临的问题得到解决」的能力。。

这又涉及到直接能力和间接能力,,缺乏直接能力很正常,视情况可以通过学习来掌握直接能力,或者「请」有直接能力的人来帮自己解决。。

缺乏间接能力的情况是真没救,尤其是对「这是**我自己**面临的问题」这一前提没有明确认知的人。。

最新留言

友情链接