奇怪的用法又增加了,这回是直接在思源里直接伺服思源的源码

本贴最后更新于 1014 天前,其中的信息可能已经时过境迁

奇怪的用法增加了:通过渲染进程在思源中拉起子应用 - 链滴 (ld246.com)

上面那个帖子介绍了在新的渲染进程中拉服务的办法。

electron 的渲染进程又是有 node 环境的对吧, 所以我们可以用它来做一些奇怪的事情。

比如说直接把思源的前端代码拉到应用里跑着玩。

但是我们知道思源的源码都是 ts 嘛,所以需要搞一点点小操作,比如说把它转译成 js 之后伺服。

转译的部分挺长的就直接放 github 链接算了,老哥们应该都能够看到吧。。。。。

naive/script/coreServicies/compiler at master · leolee9086/naive (github.com)

不过直接跑是跑不了的,pdfjs.js 那里会出问题,不过只要改改就行了

·

/* Copyright 2016 Mozilla Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* globals module, __non_webpack_require__ */ "use strict"; import {addScriptSync} from '../../protyle/util/addScript' import {Constants} from '../../constants' addScriptSync(`${Constants.PROTYLE_CDN}/js/pdf/pdf.js`, 'pdfjsScript') export default window["pdfjs-dist/build/pdf"] export let __esModule = window["pdfjs-dist/build/pdf"]["__esModule"] export let AnnotationEditorLayer = window["pdfjs-dist/build/pdf"]["AnnotationEditorLayer"] export let AnnotationEditorParamsType = window["pdfjs-dist/build/pdf"]["AnnotationEditorParamsType"] export let AnnotationEditorType = window["pdfjs-dist/build/pdf"]["AnnotationEditorType"] export let AnnotationEditorUIManager = window["pdfjs-dist/build/pdf"]["AnnotationEditorUIManager"] export let AnnotationLayer = window["pdfjs-dist/build/pdf"]["AnnotationLayer"] export let AnnotationMode = window["pdfjs-dist/build/pdf"]["AnnotationMode"] export let CMapCompressionType = window["pdfjs-dist/build/pdf"]["CMapCompressionType"] export let GlobalWorkerOptions = window["pdfjs-dist/build/pdf"]["GlobalWorkerOptions"] export let InvalidPDFException = window["pdfjs-dist/build/pdf"]["InvalidPDFException"] export let MissingPDFException = window["pdfjs-dist/build/pdf"]["MissingPDFException"] export let OPS = window["pdfjs-dist/build/pdf"]["OPS"] export let PDFDataRangeTransport = window["pdfjs-dist/build/pdf"]["PDFDataRangeTransport"] export let PDFDateString = window["pdfjs-dist/build/pdf"]["PDFDateString"] export let PDFWorker = window["pdfjs-dist/build/pdf"]["PDFWorker"] export let PasswordResponses = window["pdfjs-dist/build/pdf"]["PasswordResponses"] export let PermissionFlag = window["pdfjs-dist/build/pdf"]["PermissionFlag"] export let PixelsPerInch = window["pdfjs-dist/build/pdf"]["PixelsPerInch"] export let RenderingCancelledException = window["pdfjs-dist/build/pdf"]["RenderingCancelledException"] export let SVGGraphics = window["pdfjs-dist/build/pdf"]["SVGGraphics"] export let UNSUPPORTED_FEATURES = window["pdfjs-dist/build/pdf"]["UNSUPPORTED_FEATURES"] export let UnexpectedResponseException = window["pdfjs-dist/build/pdf"]["UnexpectedResponseException"] export let Util = window["pdfjs-dist/build/pdf"]["Util"] export let VerbosityLevel = window["pdfjs-dist/build/pdf"]["VerbosityLevel"] export let XfaLayer = window["pdfjs-dist/build/pdf"]["XfaLayer"] export let build = window["pdfjs-dist/build/pdf"]["build"] export let createPromiseCapability = window["pdfjs-dist/build/pdf"]["createPromiseCapability"] export let createValidAbsoluteUrl = window["pdfjs-dist/build/pdf"]["createValidAbsoluteUrl"] export let getDocument = window["pdfjs-dist/build/pdf"]["getDocument"] export let getFilenameFromUrl = window["pdfjs-dist/build/pdf"]["getFilenameFromUrl"] export let getPdfFilenameFromUrl = window["pdfjs-dist/build/pdf"]["getPdfFilenameFromUrl"] export let getXfaPageViewport = window["pdfjs-dist/build/pdf"]["getXfaPageViewport"] export let isPdfFile = window["pdfjs-dist/build/pdf"]["isPdfFile"] export let loadScript = window["pdfjs-dist/build/pdf"]["loadScript"] export let renderTextLayer = window["pdfjs-dist/build/pdf"]["renderTextLayer"] export let shadow = window["pdfjs-dist/build/pdf"]["shadow"] export let version = window["pdfjs-dist/build/pdf"]["version"]

就是把它改得啰嗦一点..........

naive/pdfjs.js at master · leolee9086/naive (github.com)

为啥不用 vite 呢,因为一是一开始没配置好在思源里拉起 vite 老是出问题,二是改了代码之后 vite 热更新其实也没有比直接刷新快多少(主要是因为我菜)..............

还有一个地方就是思源得源码里面是有一些像这样的代码的嘛

image.png

///#if !BROWSER ///endif

这里需要一个解析工具 ,用 vite 的老哥可以试试 vite-plugin-ifdef(之前弄得挺糙得,最好自己改改再用),不用的话就直接自己弄一下条件解析就行了。

整出来反正是能够跑起来的。

这玩意有什么用呢。。。。。。

思源的编辑器比较复杂,有的时候自己改了也不大敢往仓库 pr 对吧,但是自娱自乐的时候我又不喜欢老是要去打命令行,所以就干脆在思源里面拉一个思源得了,基本实现魔改自由(并没有,因为 V 姐肝得太快所以你的魔改代码也得跟着改...... 过不了两天就觉得就跟不动了就安心当条咸鱼算了)

image.png

上面那个就是运行效果,看起来差不多是吧,其实它是这样的

image.png

然后那天看到主仓库里有个 api.ts 但是没怎么动就自己玩了一下。。。

image.png

所以说到底还是并无什么卵用.......

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    26744 引用 • 111449 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    86 引用 • 165 回帖
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 567 关注
  • V2Ray
    1 引用 • 15 回帖 • 5 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    415 引用 • 3601 回帖
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    27 引用 • 287 回帖 • 1 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    292 引用 • 4495 回帖 • 663 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 508 关注
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 45 关注
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 266 关注
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖 • 3 关注
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    107 引用 • 127 回帖 • 339 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 234 回帖 • 2 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 59 回帖
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 451 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 12 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 114 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    29 引用 • 230 回帖 • 123 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖 • 1 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    211 引用 • 358 回帖
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    326 引用 • 1395 回帖
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 67 回帖 • 447 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 72 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 646 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    59 引用 • 25 回帖 • 2 关注