Git Product home page Git Product logo

disqusjs's Introduction

DisqusJS

超轻量级的「评论基础模式」实现:使用 Disqus API 渲染评论列表

npm version Author npm license Size Travis Codacy Badge Dependency Status jsDelivr Hits

简介

使用 Disqus API 获取到的数据渲染评论列表,搭配 Disqus API 的反代可以实现在网络审查地区加载 Disqus 评论列表;支持自动检测访客的 Disqus 可用性自动选择加载原生 DISQUS(评论完整模式)和 DisqusJS 提供的评论基础模式。

功能

  • 展示评论列表
  • 自动判断访客的 DISQUS 可用性选择「评论基础模式」或「Disqus 完整模式」

Demo

使用

安装

直接引入

首先下载 经过编译和压缩的 DisqusJS 相关文件,在你需要安装 DisqusJS 的页面的 </head> 之前引入 DisqusJS 的 css,在需要在需要显示评论的位置引入 DisqusJS 的 js:

<link rel="stylesheet" href="disqusjs.css">
<script src="disqus.js"></script>

你也可以使用 CDN 加载上述文件:

<!-- Unpkg -->
<link rel="stylesheet" href="https://unpkg.com/[email protected]/dist/disqusjs.css">
<script src="https://unpkg.com/[email protected]/dist/disqus.js"></script>

<!-- jsDelivr -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/[email protected]/dist/disqusjs.css">
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/disqus.js"></script>

从 NPM 安装

你可以轻松将 DisqusJS 引入你现有的项目:

npm i --save disqusjs
import 'disqusjs/dist/disqusjs.css'
import DisqusJS from 'disqusjs'

使用

创建一个 DisqusJS 的容器:

<div id="disqus_thread"></div>

这个容器和 Disqus 原版评论的容器相同。

使用下述代码初始化一个 DisqusJS 实例,注意初始化需在 DisqusJS 加载完成后执行:

<script>
var dsqjs = new DisqusJS({
    shortname: '',
    siteName: '',
    identifier: '',
    url: '',
    title: '',
    api: '',
    apikey: '',
    admin: '',
    adminLabel: ''
});
</script>

完成上述步骤后,DisqusJS 就已经在您的站点安装好了,但是你现在还不能使用它。要使用 DisqusJS,你还需要进行一些配置。

配置 Disqus Application

Disqus API Application 处注册一个 Application。

点击新创建的 Application,获取你的 API Key(公钥)。

在 Application 的 Settings 页面设置你的域名,Disqus 会检查 API 请求的 Referrer。

配置 DisqusJS 参数

shortname {string}

siteName {string}

identifier {string}

  • 当前页面的 identifier,用来区分不同页面
  • 建议,默认值为 document.location.origin + document.location.pathname + document.location.search

url {string}

  • 当前页面的 URL,Disqus 的爬虫会爬取该 URL 获取页面相关信息
  • 建议,默认值为 document.location.origin + document.location.pathname + document.location.search

title {string}

  • 当前页面的标题,如果没有设置默认为当前页面的标题。当页面标题中有其他信息(比如站点名称)而不想在 Disqus 中展示时,可以设置此项。
  • 非必须,默认值为 document.title

api {string}

  • DisqusJS 请求的 API Endpoint,通常情况下你应该配置一个 Disqus API 的反代并填入反代的地址。你也可以直接使用 DISQUS 官方 API 的 Endpoint https://disqus.com/api/,或是使用我搭建的 Disqus API 反代 Endpoint https://disqus.skk.moe/disqus/。如有必要可以阅读关于搭建反代的 相关内容
  • 建议,默认值为 https://disqus.skk.moe/disqus/

apikey {string || Array}

  • DisqusJS 向 API 发起请求时使用的 API Key,你应该在配置 Disqus Application 时获取了 API Key
  • DisqusJS 支持填入一个 包含多个 API Key 的 Array,在每次请求时会随机使用其中一个;如果你只填入一个 API Key,可以填入 string 或 Array。
  • 必填,无默认值

以下配置和 Disqus Moderator Badge 相关,缺少一个都不会显示 Badge

admin {string}

adminLabel {string}


未来可能扩展的配置:

  • nesting 最大评论嵌套数(超过嵌套层数的评论会显示在同一层级下,目前该值采用 Disqus 官方 4 级嵌套且不可改变)
  • nocomment 没有评论时的提示语(对应 Disqus Admin - Settings - Community - Comment Count Link - Zero comments)
  • commentPolicyURL 站点评论政策 URL(对应 对应 Disqus Admin - Settings - General - Comment Policy URL)
  • commentPolicyText 站点评论政策简介(对应 对应 Disqus Admin - Settings - General - Comment Policy Summary)
  • newcomment 是否允许添加新评论(目前增加评论功能尚未实现)

PJAX 站点注意事项

如果你在使用 DisqusJS v0.2.5 版本,需要在 PJAX 的页面跳转事件下销毁 Disqus 实例(Disqus 不支持 PJAX)、并通过 window.disqusjs.load(); 重新加载 DisqusJS。DisqusJS v0.2.5 版本支持自动判断当前页面是否存在 #disqus_thread 容器,如果容器不存在就不加载。

DisqusJS v1.0.0 及之后的版本使用了新的方法加载 DisqusJS,并去除了对 #disqus_thread 容器的判断,在没有容器的页面初始化 DisqusJS 实例会报错。在切换页面时需要销毁已有的 Disqus 实例和 DisqusJS 实例,然后重新初始化一个新的 DisqusJS 实例。

代码可以参考 DIYgod 的这条 commit,DIYgod 在这次 commit 中将 DisqusJS 从 v0.2.5 升级到了 v1.0.8。

如何搭建 Disqus API 反代

使用 Caddy 或者 Nginx 都可以搭建一个反代服务器,需要反代的 Endpoint 是 https://disqus.com/api/。这里介绍的是针对不使用服务器和后端程序,使用 Serverless 平台搭建 Disqus API 反代的方法。

当然,你也可以直接使用我搭建的反代 https://disqus.skk.moe/disqus/

ZEIT Now

ZEIT Now 是一个 Serverless 平台,免费 Plan 提供每月 100GiB 流量。 sukkaw/disqusjs-proxy-example 提供了一个使用 Now Router 进行反代的样例配置文件。

Cloudflare Workers

Cloudflare Workers 提供了一个在 Cloudflare 上运行 JavaScript 的平台。在 workers.dev 域名上部署可提供每天 100000 次免费请求次数额度,在自己的域名上部署提供 10M 次免费请求额度(超出收费)。 idawnlight/disqusjs-proxy-cloudflare-workers 提供了一份使用 Cloudflare Workers 进行反代的样例代码。

注意

  • Disqus API 不支持通过 AJAX 方式调用创建评论或者初始化页面,所以自动初始化页面和创建匿名评论在不搭配专门的后端程序的话不能实现。
  • 所以如果 DisqusJS 检测到当前页面没有初始化、会提示是否切换到 Disqus 完整模式进行初始化。
  • DisqusJS 仅在当前域名首次访问时检测 Disqus 可用性并选择模式,并把结果持久化在 localStorage 中,之后访问都会沿用之前的模式。
    • 一些广告拦截规则(如 Fanboy’s Enhanced Tracking List) 会导致检测失败,可在广告拦截器的自定义规则中添加 @@||*disqus*.com/favicon.ico* 解决。
  • 一个 Disqus Application 的 Rate Limit 是每小时 1000 次;DisqusJS 一次正常加载会产生 2 次请求。DisqusJS 支持填入多个 API Key,你可以创建多个 Disqus API Application 并分别获取 API Key。
  • 我搭建了一个 Disqus API 反代的服务 https://disqus.skk.moe/disqus/ 供没有能力搭建反代的用户使用,不保证 SLA、缓存 TTL 1 小时。

谁在使用 DisqusJS?

如果你的站点或者个人博客在使用 DisqusJS,来 把你的网站分享给其他人吧

调试、进阶使用 & 开发相关

  • a.disquscdn.comc.disquscdn.com 解析到 Cloudflare 而不是 Fastly,可用性大大增强;disqus.comshortname.disqus.com 仍然被墙;disq.us 解析到 Fastly 连通性较差,DisqusJS 通过解析获得了原链接。
  • DisqusJS 检测访客的 Disqus 可用性是通过检测 disqus.com/favicon.ico${disqusjs.config.shortname}.disqus.com/favicon.ico 是否能正常加载,如果有一个加载出错或超时(2s)就判定 Disqus 不可用。
  • DisqusJS 在 localStorage 中持久化了 Disqus 连通性检查结果,key 为 dsqjs_mode,value 为 disqus 或者 dsqjs。需要调整 DisqusJS 的模式时可以直接操作 localStorage。
  • Disqus 自己的 config 保存在全局变量 window.disqus_config 中,你可能好奇为什么没有引入。实际上由于 disqus_config 和 DisqusJS 中有很多重复的配置,所以 DisqusJS 直接将相关配置项赋给了 disqus_config,所以用户只需要配置 DisqusJS 即可。
  • DisqusJS 并没有使用 Webpack 将 disqusjs.cssdisqus.js 打包在一起,大家可以开发自己的 DisqusJS 主题。所有 DisqusJS 创建的 HTML 元素都在 <div id="dsqjs"></div> 之中、几乎所有的元素都有自己的类名并都以 dsqjs- 为前缀,防止污染。
  • DisqusJS 从 v1.2.0 版本开始实现了评论排序。Disqus 将评论排序方式持久化在 localStorage 中、key 为 disqus.sort,DisqusJS 沿用了这一位置。

Todo List

DisqusJS GitHub Project

Author 作者

DisqusJS © Sukka, Released under the MIT License.
Authored and maintained by Sukka with help from contributors (list).

Personal Website · Blog · GitHub @SukkaW · Telegram Channel @SukkaChannel · Twitter @isukkaw · Keybase @sukka

disqusjs's People

Contributors

dependabot[bot] avatar giuem avatar h404bi avatar imlonghao avatar kidonng avatar luyilin avatar renovate[bot] avatar sukkaw avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.