Gitment是一个基于GitHub问题的评论系统,可以在没有任何服务器端实现的前端使用。

演示页面

中文简介

特征

  • GitHub登录
  • Markdown / GFM支持
  • 语法突出显示
  • 来自GitHub的通知
  • 易于定制
  • 没有服务器端实现

入门

1.安装

< link  rel = “ stylesheet ”  href = “ https://imsun.github.io/gitment/style/default.css ” >
< script  src = “ https://imsun.github.io/gitment/dist/gitment.browser.js ” > < / script >

或通过npm:

$ npm i  - 保存gitment
 从' gitment '导入' gitment / style / default.css '
导入 Gitment

2.注册OAuth应用程序

单击此处注册OAuth应用程序,您将获得客户端ID和客户端密钥。

确保回调网址正确。通常它是您网站的起源,例如https://imsun.net

3.渲染Gitment

const  gitment  =  new  Gitment({
id : '您的页面ID ',//可选
所有者: '您的GitHub ID ',
repo : '存储评论的回购',
oauth : {
client_id : '您的客户ID ',
client_secret : '你的客户秘密',
},
// ...
//有关更多可用选项,请查看以下文档
}) gitment。render(' comments ')
//或
// gitment.render(document.getElementById('comments'))
//或
// document.body.appendChild(gitment.render())

4.初始化您的评论

页面发布后,您应该访问您的页面,使用您的GitHub帐户登录(确保您是repo的所有者),然后单击初始化按钮,在您的仓库中创建相关问题。在那之后,其他人可以留下他们的评论。

方法

构造器(选项)

选项:

类型: object

  • 所有者:您的GitHub ID。需要。
  • repo:存储您的评论的存储库。确保你是回购的所有者。需要。
  • oauth:对象包含您的客户端ID和客户端密钥。需要。
    • client_id:GitHub客户端ID。需要。
    • client_secret:GitHub客户端密钥。需要。
  • id:用于标识页面的可选字符串。默认location.href
  • title:页面的可选标题,用作问题标题。默认document.title
  • link:您页面的可选链接,用于问题正文。默认location.href
  • desc:页面的可选描述,用于问题的正文。默认''
  • labels:创建问题时要添加的可选标签数组。默认[]
  • theme:可选的Gitment主题对象。默认gitment.defaultTheme
  • perPage:注释将被分页的可选数字。默认20
  • maxCommentHeight:一个可选数字,用于限制注释的最大高度,注释将被折叠。默认250

gitment.render([元素])

元件

输入:HTMLElementstring

要呈现注释的DOM元素。可以是HTML元素或元素的id。省略时,此函数将创建一个新div元素。

此函数返回要呈现注释的元素。

gitment.renderHeader([元素])

同样的gitment.render([element])。但只渲染标题。

gitment.renderComments([元素])

同样的gitment.render([element])。但只呈现评论列表。

gitment.renderEditor([元素])

同样的gitment.render([element])。但只能渲染编辑器。

gitment.renderFooter([元素])

同样的gitment.render([element])。但只会呈现页脚。

gitment.init()

初始化新页面。Promise初始化时返回a 并解析。

gitment.update()

更新数据和视图。返回a Promise并在数据更新时解析。

gitment.post()

在编辑器中发表评论。Promise发布时返回a 并解析。

gitment.markdown(文本)

文本

类型: string

返回Promise并解析呈现的文本。

gitment.login()

跳转到GitHub OAuth页面进行登录。

gitment.logout()

注销当前用户。

转到页面)

类型: number

跳转到评论的目标页面。请注意,page1Promise加载注释时返回a 并解析。

gitment.like()

喜欢当前页面。返回a Promise并在喜欢时解析。

gitment.unlike()

与当前页面不同。Promise不受欢迎时返回a 并解析。

gitment.likeAComment(commentId)

commentId

类型: string

喜欢评论。返回a Promise并在喜欢时解析。

gitment.unlikeAComment(commentId)

commentId

类型: string

与评论不同。Promise不受欢迎时返回a 并解析。

定制

Gitment很容易定制。您可以使用自己的CSS或编写主题。(区别在于自定义CSS无法修改DOM结构)

使用自定义CSS

Gitment不使用任何原子CSS,使定制更容易,更灵活。您可以在浏览器中检查DOM结构并编写自己的样式。

写一个主题

Gitment主题是一个包含多个渲染函数的对象。

默认情况下,Gitment有五个渲染功能:renderrenderHeaderrenderCommentsrenderEditorrenderFooter。最后四个渲染独立的组件和render函数将它们组合在一起。所有这些都可以独立使用。

您可以覆盖上面的任何渲染函数或编写自己的渲染函数。

例如,您可以覆盖render函数以将编辑器放在注释列表之前,并呈现新组件。

const  myTheme  = {
render(state,instance){
const container = document。createElement(' div ')
容器。lang = “ en-US ”
容器。className = ' gitment-container gitment-root-container ' //您的自定义组件
容器。的appendChild(实例。 renderSomething(状态,实例)) 容器。的appendChild(实例。renderHeader(状态,实例))
容器。的appendChild(实例。的renderEditor(状态,实例))
容器。的appendChild(实例。renderComments(状态,实例))
容器。使用appendChild(实例。renderFooter(州,实例))
返回容器
},
renderSomething(state,instance){
const container = document。createElement(' div ')
容器。郎 = “的en-US ”
如果(状态。用户。登录){
容器。innerText = ` Hello,$ { state。用户。登录} `
}
返回容器
}
} const gitment = new Gitment({
// ...
主题: myTheme,
}) gitment。渲染(文件。体)
//或
// gitment.renderSomthing(document.body的)

每个渲染函数都应该接收一个状态对象和一个gitment实例,并返回一个HTML元素。它将被包装附加到具有相同名称的Gitment实例。

Gitment使用MobX来检测渲染函数中使用的状态。一旦使用状态改变,Gitment将调用render函数来获取一个新元素并进行渲染。未使用状态的更改不会影响渲染元素。

可用状态:

  • 用户:object。用户信息从GitHub Users API返回,另外还有两个键。

    • isLoggingIn : bool. 指示用户是否正在登录。
    • 来自小姐:bool。Gitment将缓存用户的信息。其值指示当前用户信息是否来自缓存。
  • 错误:Error Object。如果没有错误,则为null。
  • meta : object. 从GitHub Issues API返回问题的信息。
  • 评论:array。从GitHub Issue Comments API返回的注释数组。将undefined注释未加载时。
  • 反应:array。从GitHub Issues'Reactions API返回的添加到当前页面的一系列反应。
  • commentReactions : object. 添加到注释的反应对象,注释ID为关键,从GitHub Issue Comments'Reactions API返回
  • currentPage : number. 用户在哪个评论页面。从...开始1

关于安全

让我的客户秘密公开是否安全?

OAuth需要客户端密码,否则用户无法使用其GitHub帐户登录或评论。虽然GitHub不建议在前端硬编码客户端密码,但你仍然可以这样做,因为GitHub会验证你的回调URL。从理论上讲,除了你的网站,没有其他人可以使用你的秘密。

如果您找到了破解它的方法,请打开一个问题

为什么Gitment向gh-oauth.imsun.net发送请求?

https://gh-oauth.imsun.net是一个简单的开源服务,用于在用户登录期间代理一个请求。因为GitHub没有附加CORS头。

此服务不会记录或存储任何内容。它只将CORS标头附加到该请求并提供代理。这样用户就可以在没有任何服务器端实现的情况下登录前端。

Hexo+gitment的更多相关文章

  1. 关于hexo博客自定义域名后gitment评论系统登陆出现redirect error返回主页的解决办法

    title: 关于hexo博客自定义域名后gitment评论系统登陆出现redirect error返回主页的解决办法 toc: false date: 2018-04-16 22:57:50 cat ...

  2. 接入gitment为hexo添加评论功能

    title: 接入gitment为hexo添加评论功能 toc: false date: 2018-04-16 10:59:56 categories: methods tags: hexo gitm ...

  3. 将hexo的评论系统由gitment改为Valine

    title: 将hexo的评论系统由gitment改为Valine toc: false date: 2018-09-13 15:10:56 categories: methods tags: hex ...

  4. hexo部署github和gitment操作简单介绍

    优点: 快速高效 支持markdown 布局自定义简单,无广告 部署简单 因为想开始写博客,但又找不到好的博客平台,平时都看博客园和开源中国看博客文章,但博客园的那个皮肤是真有点难受,所以就想自己打个 ...

  5. Hexo博客yilia主题添加Gitment评论系统

    一开始搭建hexo+yilia博客使用的评论功能是通过来必力实现的.来必力免费,功能多,一开始的体验效果很好,但是后来打开网站发现来必力加载的越来越慢(来必力是韩国的公司,可能是国内限制),遂打算换一 ...

  6. Hexo Next配置百度分享、加入动态背景、接入网页在线联系功能、页脚增加统计功能、添加gitment、添加热度、阅读量排行

    Hexo Next配置百度分享.加入动态背景.接入网页在线联系功能.页脚增加统计功能.添加gitment.添加热度.阅读量排行: https://wangc1993.github.io/categor ...

  7. 为hexo博客添加基于gitment评论功能

    关于gitment gitment其实就是利用你的代码仓库的Issues,来实现评论.每一篇文章对应该代码仓库中的 一个Issues,Issues中的评论对应你的博客每篇文章中的评论.如果你是用git ...

  8. 为 hexo NexT 添加 Gitment 评论插件

    Gitment 是作者imsun实现的一款基于 GitHub Issues 的评论系统. 支持在前端直接引入, 不需要任何后端代码. 可以在页面进行登录, 查看, 评论, 点赞等操作. 同时有完整的 ...

  9. 基于 Hexo + GitHub Pages 搭建个人博客(三)

    一.添加扫描二维码关注功能 打开 themes 目录下的 next 主题配置文件,找到 Wechat Subscriber 标签,将该标签下的配置改成如下形式: # Wechat Subscriber ...

随机推荐

  1. 关于如何解决bootstrap table 列 切换 刷新 高度不一样

    在使用bootstrap table时候,碰到bootstrap table 列 切换 刷新 高度不一样的问题,如图所示: 解决这个问题很简单,在你的页头加一句<!DOCTYPE html> ...

  2. Web—08-移动端库和框架

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件包括如下几个事件: 1.touchstart: //手指放到屏幕上时触发 2.touc ...

  3. iview-cli 项目、iView admin 代理与跨域问题解决方案

    iview-cli 项目.iView admin 跨域.代理问题解决方案 在webpack.dev.config.js文件中: 添加: devServer: { historyApiFallback: ...

  4. js时间与毫秒互相转换

    1)日期转换为毫秒 如果格式是:yyyy/mm/dd hh:mm:ss可以直接转换.var oldTime = (new Date("2018/07/09 14:13:11")). ...

  5. jsp小基础归纳

    JSP的本质就是一个Servlet,JSP的运行之前会先被Tomcat服务器翻译为.java文件,然后在将.java文本编译为.class文件,而我们在访问jsp时,处理请求的就是那个翻译后的类. 1 ...

  6. flAbsPath on /var/lib/dpkg/status failed 解决 Cydia 红字

    越狱之后抹掉所有数据,然后再使用 doubleH3lix 越狱成功后,打开 Cydia 会提示如下错误: flAbsPath on /var/lib/dpkg/status failed - real ...

  7. 4. HTML表单标签

    表单是网页中最常见的元素,也是用户和我们交互的重要手段,在网站中的登录.注册.信息更新这些功能都是依赖表单实现的.在HTML中对于表单提供了一系列的标签,即输入框.下拉框.按钮.文本域,如下是一个最常 ...

  8. PHP处理高分辨率图片的问题

    今天小伙伴在群里问了这么一个问题: 出现这种情况就是因为内存不足,PHP程序直接退出了,报错大概如下: 上图的意思就是说,我们能使用的内存最大是8M,但是处理这个图片还需要额外的41bytes,就会导 ...

  9. sqoop import/export使用经验

    一.先创建一个小表(test_01)进行测试(主节点IP:169.254.109.130/oracle服务器IP:169.254.109.100) 1.测试连接oracle; sqoop list-t ...

  10. BurpSuite—-Target模块(目标模块)

    Target功能 目标工具包含了SiteMap,用你的目标应用程序的详细信息.它可以让你定义哪些对象在范围上为你目前的工作,也可以让你手动测试漏洞的过程,Target分为site map和scope两 ...