Hexo+gitment
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([元素])
元件
输入:HTMLElement或string
要呈现注释的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
跳转到评论的目标页面。请注意,page从1。Promise加载注释时返回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有五个渲染功能:render,renderHeader,renderComments,renderEditor,renderFooter。最后四个渲染独立的组件和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将缓存用户的信息。其值指示当前用户信息是否来自缓存。
- isLoggingIn :
- 错误:
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的更多相关文章
- 关于hexo博客自定义域名后gitment评论系统登陆出现redirect error返回主页的解决办法
title: 关于hexo博客自定义域名后gitment评论系统登陆出现redirect error返回主页的解决办法 toc: false date: 2018-04-16 22:57:50 cat ...
- 接入gitment为hexo添加评论功能
title: 接入gitment为hexo添加评论功能 toc: false date: 2018-04-16 10:59:56 categories: methods tags: hexo gitm ...
- 将hexo的评论系统由gitment改为Valine
title: 将hexo的评论系统由gitment改为Valine toc: false date: 2018-09-13 15:10:56 categories: methods tags: hex ...
- hexo部署github和gitment操作简单介绍
优点: 快速高效 支持markdown 布局自定义简单,无广告 部署简单 因为想开始写博客,但又找不到好的博客平台,平时都看博客园和开源中国看博客文章,但博客园的那个皮肤是真有点难受,所以就想自己打个 ...
- Hexo博客yilia主题添加Gitment评论系统
一开始搭建hexo+yilia博客使用的评论功能是通过来必力实现的.来必力免费,功能多,一开始的体验效果很好,但是后来打开网站发现来必力加载的越来越慢(来必力是韩国的公司,可能是国内限制),遂打算换一 ...
- Hexo Next配置百度分享、加入动态背景、接入网页在线联系功能、页脚增加统计功能、添加gitment、添加热度、阅读量排行
Hexo Next配置百度分享.加入动态背景.接入网页在线联系功能.页脚增加统计功能.添加gitment.添加热度.阅读量排行: https://wangc1993.github.io/categor ...
- 为hexo博客添加基于gitment评论功能
关于gitment gitment其实就是利用你的代码仓库的Issues,来实现评论.每一篇文章对应该代码仓库中的 一个Issues,Issues中的评论对应你的博客每篇文章中的评论.如果你是用git ...
- 为 hexo NexT 添加 Gitment 评论插件
Gitment 是作者imsun实现的一款基于 GitHub Issues 的评论系统. 支持在前端直接引入, 不需要任何后端代码. 可以在页面进行登录, 查看, 评论, 点赞等操作. 同时有完整的 ...
- 基于 Hexo + GitHub Pages 搭建个人博客(三)
一.添加扫描二维码关注功能 打开 themes 目录下的 next 主题配置文件,找到 Wechat Subscriber 标签,将该标签下的配置改成如下形式: # Wechat Subscriber ...
随机推荐
- 阅读AuTO利用深度强化学习自动优化数据中心流量工程(一)
目录 问题 解决方法 模型选择 框架构建 Sigcomm'18 AuTO: Scaling Deep Reinforcement Learning for Datacenter-Scale Autom ...
- Gradle Goodness: Parse Files with SimpleTemplateEngine in Copy Task
With the copy task of Gradle we can copy files that are parsed by Groovy's SimpleTemplateEngine. Thi ...
- koa2学习笔记01 - 创建项目 —— koa生成器一键生成koa项目
前言 从17年开始尝试学习搭建个人网站开始,就开始学习摸索node了,至今差不多快两年了. 说起来现在都9102年了,所以最近打算整体设计重构一下网站,索性node后台也重写一遍. 重温一下node, ...
- float(浮动)的属性和使用方法
1float浮动的属性值 left:向左浮动 right:向右浮动 2.当父元素未浮动,子元素浮动时,就会造成浮动塌陷 实例: 父元素: #mainDiv{ border: 5px solid red ...
- Wtrofms
一.安装 安装:pip3 install wtforms 二.使用1(登录) from flask import Flask, render_template, request, redirect f ...
- C语言不定型参数函数定义
我们在C语言中定义一个函数,通常都是需要在函数原型中规定这个函数需要提供什么类型的参数以及需要提供多少个.也就是,你的参数必须明确.但是我们调用函数库中的printf和scanf函数会发现,它们似乎是 ...
- Asp.Net Core跨域配置
在没有设置跨域配置的时候,Ajax请求时会报以下错误 已拦截跨源请求:同源策略禁止读取位于 http://localhost:5000/Home/gettime 的远程资源.(原因:CORS 头缺少 ...
- 时间戳Unix timestamp
(1)定义 Unix时间戳(Unix timestamp),或称Unix时间(Unix time).POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间1970年01月01 ...
- 并查集(模板&典型例题整理)
参考:https://blog.csdn.net/oliver233/article/details/70162173 带路径压缩模板: #include<stdio.h> ]; int ...
- 20155217 2016-2017-2《Java程序设计》课程总结
20155217 2016-2017-2<Java程序设计>课程总结 每周作业链接汇总 预备作业一:我所期望的师生关系 预备作业二:c与java的关系 预备作业三:安装虚拟机 第一周作业: ...