[油猴脚本]文章拷贝助手,文章一键拷贝到微信公众平台

sxkk20082年前知识分享173

文章拷贝助手,文章一键拷贝到微信公众平台、知乎 下载 markdown

image.png

为什么要写这个脚本

最近开了个前端公众号,需要推送一些优质的文章,但由于时间的关系,原创内容太少,常规的做法是转载一些优秀的文章到自己的公众号。

流程

image.png

使用脚本流程

image.png

HTML 转 markdown

https://www.bejson.com/convert/html2markdown/

https://devtool.tech/html-md

https://github.com/mixmark-io/turndown

使用

实现代码

大部分代码来自 markdown-nice

javascript 实现下载 markdown 文件, 掘金是使用 NUXT.js 来实现的 ssr, 所以 会将全部的数据保存在全局对象中 NUXT

__NUXT__.state.view.column.entry.article_info.mark_content 这样就可以直接取到 markdown 文件内容了,

但是有用户写文章的时候不是用 markdown 写的, 是用富文本编辑器来写的,这个时候就没有 mark_content 数据了,这个时候就要涉及到 HTML 转 markdown

我们可以使用 turndown 这个库来实现。

下载文件 js

export const downLoad = (filename, code) => {
  // 下载的文件名
  var file = new File([code], filename, {
    type: 'text/markdown',
  })
  // 创建隐藏的可下载链接
  var eleLink = document.createElement('a')
  eleLink.download = filename
  eleLink.style.display = 'none'
  // 下载内容转变成blob地址
  eleLink.href = URL.createObjectURL(file)
  // 触发点击
  document.body.appendChild(eleLink)
  eleLink.click()
  // 然后移除
  document.body.removeChild(eleLink)
}

复制实现

使用剪切板 api event.clipboardData.setData() 这个是现代浏览器都支持的 api

简单示例

document.addEventListener('copy', function (e) {
  e.clipboardData.setData('text/plain', 'foo')
  e.preventDefault() // 阻止浏览器默认事件
})

通过以上代码就可以用 JavaScript 来修改剪切板的内容了,需要注意的是阻止浏览器默认事件

document.getElementById('copyBtn').onclick = function () {
  document.execCommand('copy')
}

然后需要触发复制

最终代码

export const copySafari = (text) => {
  // 获取 input
  let input = document.getElementById('copy-input')
  if (!input) {
    // input 不能用 CSS 隐藏,必须在页面内存在。
    input = document.createElement('input')
    input.id = 'copy-input'
    input.style.position = 'absolute'
    input.style.left = '-1000px'
    input.style.zIndex = '-1000'
    document.body.appendChild(input)
  }
  // 让 input 选中一个字符,无所谓那个字符
  input.value = 'NOTHING'
  input.setSelectionRange(0, 1)
  input.focus()

  // 复制触发
  document.addEventListener('copy', function copyCall(e) {
    e.preventDefault()
    e.clipboardData.setData('text/html', text)
    e.clipboardData.setData('text/plain', text)
    document.removeEventListener('copy', copyCall)
  })
  document.execCommand('copy')
}

TODO

未来需要兼容更多平台

  • 简书
  • 思否
  • CSDN

Github

tampermonkey-copy-helper

以上就是本文全部内容,希望这篇文章对大家有所帮助,也可以参考我往期的文章或者在评论区交流你的想法和心得,欢迎一起探索前端。

相关文章

人脸搜索:探索人工智能领域的创新技术

人脸搜索:探索人工智能领域的创新技术

  人脸搜索作为人工智能领域的创新技术,正以其卓越的特性和广泛的应用领域吸引着越来越多的关注。随着科技的不断进步和人工智能算法的不断优化,人脸搜索正日益成为现代社会有效管理、...

AI机器人:从人工向智能演进的里程碑

AI机器人:从人工向智能演进的里程碑

  随着人工智能技术快速发展,越来越多的AI机器人开始涌现出来,成为改变我们生活和工作方式的关键技术之一。AI机器人的发展历程注定与人工密不可分,本文将介绍AI机器人的人工之...

AI技术助力音乐在线识别:探索新媒体时代的音乐鉴赏之旅

AI技术助力音乐在线识别:探索新媒体时代的音乐鉴赏之旅

  在数字化浪潮的冲击下,音乐作为一种重要的艺术形式,也逐渐发生了巨大的创新。新媒体的兴起为人们提供了更加便捷、多样化的音乐服务,进而催生了诸如音乐在线识别等一系列创新技术。...

2022 在微笑中成长

2022 在微笑中成长

哈喽,大家好, 我是Ai知识分享,2022 年不知不觉已经过半了,看到朋友圈关于年中总结的文章,一时间不知道该如何写起,有的升 P8 了,有的拿到了新 offer,去了新公司,有的因疫情遭裁员,开始创...

AI图像识别:引领数字时代的视觉创新

AI图像识别:引领数字时代的视觉创新

  在当今数字化的时代,AI图像识别正逐渐成为新兴媒体领域的焦点。随着科技的不断进步,AI图像识别正发挥着越来越关键的作用,改变着我们的生活。无论是在商业领域还是在个人生活中...

AI人工智能网站的重要性及应用领域:连接世界的知识和信息平台

AI人工智能网站的重要性及应用领域:连接世界的知识和信息平台

  随着科技的不断发展,人工智能(AI)正逐渐渗透到我们生活的方方面面。AI技术的普及使得各类AI人工智能网站成为了人们获取信息、进行交流和实现自我提升的重要平台。在这篇文章...

发表评论    

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