obsidian 本身是不开源的,但大多数插件开源,正在看它的思路,官网的 demo 是:
https://github.com/obsidianmd/obsidian-sample-plugin
这个 demo 只有一个源文件 main.ts:(主要是想知道 demo 怎么调用到 obsidian 内部的 loadData())
// main.ts
// 下面的 obsidian 通过 npm i obsidian 安装,
// 但是./node_modules/obsidian/的所有文件都是.d.ts 文件,没有任何函数实现
import { ......, Plugin, ...... } from 'obsidian';
export default class MyPlugin extends Plugin { // demo 插件的主类
......
async loadSettings() {
// demo 里面没有 loadData()的实现,也就是它调用了父类 Plugin::loadData()
this.settings = Object.assign({}, DEFAULT_SETTINGS, await this.loadData());
}
......
}
父类 Plugin 代码在./node_modules/obsidian/obsidian.d.ts:
// obsidian.d.ts
export abstract class Plugin extends Component {
......
loadData(): Promise<any>;
......
}
不管是 Plugin 还是 Component ,都没有 loadData 的实现,只有定义
loadData 应该是在 Obsidian 里面实现的,那么 MyPlugin 是怎么调用到 Obsidian 里面的 loadaData 函数呢?
希望大佬不吝赐教,万分感谢。
1
wjx0912 OP |
2
suyi2015 85 天前
`obsidian.d.ts`只是 ts 版本的类型定义而已,不是具体的实现。
|
3
Belmode 85 天前 via Android
打个断点,跟进去
|
4
lee88688 84 天前
也可以看看 vs code 插件思路
|
5
crocoBaby 84 天前
hello Kitty 现在技术这么强?之前还像萌新来着
|
10
mtjgu 84 天前
看看那使用这个类 感觉是一个抽象基类
|
11
LuckyLauncher 84 天前
我记得 ob 的插件是运行在渲染进程的,所以你可以在界面上打开开发者工具,然后进行调试
|
12
EchoWhale 84 天前 via iPhone
无责任猜测:
它把源码的实现藏起来了,只给你定义。然后运行的时候通过扩展原型链来让插件可以访问到 loadData 方法,比如: Object.assign(MyPlugin, { loadData() {…} }) |
13
EchoWhale 84 天前 via iPhone
Object.assign(MyPlugin.prototype, {
loadData() {…} }) |
14
wjx0912 OP @mtjgu @LuckyLauncher 谢谢
|