客户端 API
大约 3 分钟...
客户端 API
Waline 提供三个 API:
init
: 初始化 WalinecommentCount
: 评论数统计pageviewCount
: 访问量统计
以及:
RecentComment
: 最近评论UserList
: 用户列表version
: Waline 客户端版本
init
init
函数接收一个 WalineInitOptions
初始化选项,并返回一个 WalineInstance
。
类型:
const init: (options: WalineInitOptions) => WalineInstance;
返回值:
interface WalineInstance {
/**
* Waline 被挂载到的元素
*
* @description 当通过 `el: null` 初始化,值为 `null`
*/
el: HTMLElement | null;
/**
* 更新 Waline 实例
*
* @description 只要不设置`path` 选项,更新时它就会被重置为 `windows.location.pathname`
*/
update: (newOptions?: Partial<Omit<WalineInitOptions, 'el'>>) => void;
/**
* 取消挂载并摧毁 Waline 实例
*/
destroy: () => void;
}
初始化选项接受所有 Waline 组件属性,此外,新增下列选项。
el
- 类型:
string | HTMLElement | null
- 默认值:
'#waline'
Waline 的初始化挂载器。必须是一个有效的 CSS 选择器 或 HTMLElement 对象。
如果你只需要下方的统计,请将此选项设置为 null
。
comment
- 类型:
boolean | string
- 默认值:
false
文章评论数统计,填入字符串时会作为 CSS 选择器。
pageview
- 类型:
boolean | string
- 默认值:
false
文章浏览量统计,填入字符串时会作为 CSS 选择器。
commentCount
commentCount
函数接收 WalineCommentCountOptions
选项,并负责更新页面上的文章评论数,同时返回一个可以取消当前操作的函数 WalineAbort
。
类型:
const commentCount: (options: WalineCommentCountOptions) => WalineAbort;
选项:
interface WalineCommentCountOptions {
/**
* Waline 服务端地址
*/
serverURL: string;
/**
* 评论数 CSS 选择器
*
* @default '.waline-comment-count'
*/
selector?: string;
/**
* 需要获取的默认路径
*
* @default window.location.pathname
*/
path?: string;
}
返回值:
type WalineAbort = (reason?: any) => void;
pageviewCount
pageviewCount
函数接收 WalinePageviewCountOptions
选项,并负责更新页面上的文章评论数,同时返回一个可以取消当前操作的函数 WalineAbort
。
类型:
const pageviewCount: (options: WalinePageviewCountOptions) => WalineAbort;
选项:
interface WalinePageviewCountOptions {
/**
* Waline 服务端地址
*/
serverURL: string;
/**
* 评论数 CSS 选择器
*
* @default '.waline-pageview-count'
*/
selector?: string;
/**
* 需要更新和获取的路径
*
* @default window.location.pathname
*/
path?: string;
/**
* 是否在查询时更新 path 的浏览量
*
* @default true
*/
update?: boolean;
}
返回值:
type WalineAbort = (reason?: any) => void;
挂件
RecentComments
RecentComments
是一个展示最近评论的挂件。
类型:
const RecentComments: (
options: WalineRecentCommentsOptions,
) => Promise<WalineRecentCommentsResult>;
选项:
interface WalineRecentCommentsOptions {
/**
* Waline 服务端地址
*/
serverURL: string;
/**
* 获取最新评论的数量
*/
count: number;
/**
* 需要挂载的元素
*/
el?: string | HTMLElement;
}
返回值:
interface WalineRecentCommentsResult {
/**
* 评论数据
*/
comments: WalineComment[];
/**
* 取消挂载挂件
*/
destroy: () => void;
}
UserList
UserList
是一个展示用户互动排行榜或者评论墙的挂件。
类型:
const UserList: (
options: WalineUserListOptions,
) => Promise<WalineUserListResult>;
选项:
interface WalineUserListOptions {
/**
* Waline 服务端地址
*/
serverURL: string;
/**
* 获取用户列表的数量
*/
count: number;
/**
* 需要挂载的元素
*/
el?: string | HTMLElement;
/**
* 错误提示消息所使用的语言
*
* @default 'zh-CN'
*/
lang?: string;
/**
* 自定义 waline 语言显示
*
* @see [自定义语言](https://waline.js.org/client/i18n.html)
*/
locale?: WalineLocale;
/**
* 列表模式还是头像墙模式
*
* list mode or avatar wall mode
*/
mode: 'list' | 'wall';
}
返回值:
interface WalineUserListResult {
/**
* 用户数据
*/
users: WalineUser[];
/**
* 取消挂载挂件
*/
destroy: () => void;
}
友情提示:评论区仅作评论展示,如有问题咨询请去 Github Discussion 中提问。
你认为这篇文章怎么样?
- 0
- 0
- 0
- 0
- 0
- 0
Powered by Waline v3.5.1