思源笔记 ai 开发自定义块 css+js 大型项目

你好,未来的思源笔记创作者!

欢迎阅读这份为自定义块(Custom Block)量身打造的新手指南。本指南旨在帮助像你一样,希望在思源笔记中创造出强大交互功能,但不知从何下手的新朋友。我将带你从零开始,一步步搭建一个专业的前端开发环境,并最终创建一个集成了模块化 TypeScript 和 SCSS 的、功能完善的交互式自定义块。

序章:准备工作 (Prerequisites)

在开始编码之前,你需要确保你的电脑上安装了以下工具。这些是现代前端开发的基石。

  • Node.js: 我们所有的开发都基于 Node.js 环境。请访问 Node.js 官网 下载并安装最新 LTS (长期支持) 版本。安装后,npm 包管理器也会被一并安装。
  • pnpm (推荐): 这是一个更快速、更高效的包管理器。安装完 Node.js 后,在终端(Terminal 或 PowerShell)中运行以下命令进行安装:
    npm install -g pnpm
    
    
  • 代码编辑器: 强烈推荐 Visual Studio Code (VS Code),它对 TypeScript 和 SCSS 都有着绝佳的支持,能大大提升你的开发体验。

第一步:初始化你的项目

与插件开发不同,我们的自定义块项目更加轻量,从一个干净的文件夹开始即可。

  1. 创建项目文件夹: 在你希望存放代码的地方,创建一个新的文件夹,例如 siyuan-custom-block。

  2. 进入并初始化: 打开你的终端,进入这个新创建的文件夹,然后运行以下命令来初始化项目:

    cd siyuan-custom-block
    pnpm init
    
    

    这个命令会为你生成一个 package.json 文件,这是我们项目的“身份证”。

第二步:了解并配置项目结构

现在,使用 VS Code 打开 siyuan-custom-block 文件夹。我们需要手动创建一些文件和目录,来搭建我们的开发框架。

然后下载 siyuan-custom-block 这是 github 上的源码文件

  1. 创建目录和文件请按照下面的结构,在你的项目中创建对应的文件夹和空白文件:
siyuan-custom-block/
├── src/              # 你的源代码将全部放在这里
│   ├── modules/      # (可选) 用于存放复杂功能的子模块
│   ├── index.ts      # 项目的JS/TS主入口文件
│   └── style.scss    # 项目的样式主入口文件
├── package.json      # 项目的包管理文件 (已自动生成)
├── tsconfig.json     # TypeScript 配置文件
└── webpack.config.js # Webpack 打包配置文件 (项目的“引擎”)

  1. 填充配置文件接下来,将我们之前讨论并最终确定的配置内容,分别复制粘贴到对应的文件中。这些文件共同构成了我们强大而稳定的开发环境。
  • package.json (项目清单与脚本): 定义了项目依赖(包括 SCSS 工具)和 build/dev 等便捷命令。
  • webpack.config.js (打包核心): 这是整个工作流的“大脑”,它负责将我们的 TS 和 SCSS 源代码,智能地转换成思源笔记可以无缝执行的独立 JS 和 CSS 文件。
  • tsconfig.json (TS 编译器配置): 告诉 TypeScript 编译器如何检查和编译我们的代码。
  1. 安装依赖配置好 package.json 后,在终端中运行以下命令,pnpm 会自动下载并安装所有我们需要的开发工具:
pnpm install

第三步:编写你的第一个功能

环境就绪,让我们来创造一个带有专业样式的交互功能:在块内创建一个带有悬停效果的按钮,点击它时,会用思源的通知 API 弹出一个提示。

  1. 编写样式 (src/style.scss)首先,我们专注于“外观”。打开 src/style.scss,将下面的 SCSS 代码粘贴进去。
/* 为我们的自定义块创建一个唯一的根 class,用于样式隔离 */
.qianqian-custom-block {
    padding: 12px;
    border-radius: 4px;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* 按钮的样式 */
.qianqian-custom-block button {
    padding: 8px 16px;
    border: 1px solid #dcdfe6;
    border-radius: 4px;
    cursor: pointer;
    background-color: #f4f4f5;
    color: #606266;
    transition: all 0.2s ease-in-out; // 添加过渡效果

    /* 使用 SCSS 的嵌套功能,轻松定义悬停效果 */
    &:hover {
        background-color: #409eff;
        color: #fff;
        border-color: #409eff;
        transform: translateY(-2px);
    }
}

  1. 编写逻辑 (src/index.ts)接下来,我们处理“功能”。打开 src/index.ts 文件,将下面的代码完整地粘贴进去。
// 在文件顶部,引入我们的样式文件
// Webpack看到这行,就会自动处理 style.scss
import './style.scss';

// 步骤 1: 清空当前块,防止脚本重载导致按钮重复创建
this.innerHTML = '';

// 步骤 2: 为块元素应用我们在CSS中定义的根 class
this.className = 'qianqian-custom-block';

// 步骤 3: 创建一个按钮元素 (现在不再需要用JS写样式了)
const button = document.createElement('button');
button.textContent = '点我显示提示';

// 步骤 4: 定义点击按钮时要执行的动作
const showNotification = () => {
    fetch('/api/notification/pushMsg', {
        method: 'POST',
        body: JSON.stringify({
            msg: `你好!这是一个来自块ID ${this.dataset.nodeId} 的提示。`,
            timeout: 5000,
        }),
    }).catch(error => console.error('发送通知失败:', error));
};

// 步骤 5: 将动作绑定到按钮的点击事件上
button.addEventListener('click', showNotification);

// 步骤 6: 将按钮添加到当前块元素中
this.append(button);

// 步骤 7: 返回一个“清理函数”,用于移除事件监听,防止内存泄漏
return () => {
    button.removeEventListener('click', showNotification);
    console.log('提示按钮的事件监听器已成功清理!');
};

第四步:打包你的脚本

代码写好后,我们需要将它“编译打包”成最终的产物。

  • 构建用于生产的代码:

    pnpm run build
    
    
  • 启动开发模式 (强烈推荐!):

    pnpm run dev
    
    

    运行此命令后,Webpack 会持续监控你的 src 文件夹。每当你修改并保存文件时,它都会在后台自动重新打包,极大提升开发效率!

执行成功后,项目根目录下会生成一个 dist 文件夹,里面会包含两个文件:QianQian.js 和 QianQian.css。

第五步:在思源笔记中见证奇迹

现在,让我们把劳动成果应用到思源笔记中!

  1. 获取代码:

    • 用 VS Code 打开 dist/QianQian.js 文件,复制里面的全部内容。
    • 用 VS Code 打开 dist/QianQian.css 文件,复制里面的全部内容。
    • 注意: 生成的 css 文件 /* @webpack */ 注释也要复制上去
  2. 在思源笔记插件集市找到 千千块 下载并安装,打开自定义块 CSS+JS

  3. 创建自定义块: 在思源笔记的任意文档中的任何块上

    1. 点击您想修改的块左侧的块图标(例如段落块的 ¶ 图标)。
    2. 在弹出的菜单中,选择 插件 -> “自定义块 CSS” 或 “自定义块 JS” 。
    3. 在展开的编辑区内直接输入您的代码。代码会自动保存并实时生效。

    当然,您也可以通过手动为块添加 css 或 js 自定义属性的方式来进行操作,效果是完全相同的。

  4. 查看效果: 完成后,你的自定义块里应该立刻就出现了一个漂亮的按钮!把鼠标放上去看看悬停效果,再点击它试试,屏幕中央是不是弹出了提示?

调试技巧: 在思源笔记中,按下 Ctrl+Shift+I (Windows) 或 Cmd+Opt+I (Mac) 可以打开“开发者工具”,在 Console (控制台) 标签页中,你可以看到 console.log 输出的信息,这对于查找代码错误非常有帮助。

总结

恭喜你!你已经成功创建并运行了你的第一个交互式自定义块。

回顾一下我们的步骤:

  1. 准备环境: 安装 Node.js, pnpm。
  2. 搭建项目: 创建文件夹,并配置好 package.json, webpack.config.js 和 tsconfig.json。
  3. 编写代码: 在 src 目录中,分离地编写了 index.ts (逻辑) 和 style.scss (表现)。
  4. 打包构建: 使用 pnpm run build 或 pnpm run dev 生成了独立的 JS 和 CSS 文件。
  5. 应用测试: 将脚本和样式分别粘贴到思源的 custom-js 和 custom-css 块属性中。

这只是一个开始。有了这套强大的工作流,你可以将任何现代前端技术融入到你的思源笔记块中。尽情发挥你的创造力,去打造属于你自己的、独一无二的笔记体验吧!

开发自定义块 js(大型项目) ai 提示词

AI 提示词:思源笔记自定义块js开发者助手
角色
你是一个友好、专业的前端开发伙伴,精通TypeScript和JavaScript。你不仅擅长编写代码,更乐于交流和分享知识。你深刻理解思源笔记的DOM结构和自定义块环境,并能根据我的具体需求,提供最佳的解决方案。

我们的开发环境 (非常重要)
我们正在一个基于 **Webpack** 的现代化项目环境中进行开发。请你务必理解并记住以下几点:
1. **你的任务是编写源代码**: 你需要为我生成 `src` 文件夹下的 TypeScript 源代码(`src/index.ts` 以及可能的模块文件 `src/modules/*.ts`)。
2. **打包工具会解决冲突**: 这个项目已经配置好了 Webpack,它会在后台自动解决思源笔记环境的一个核心冲突:**ES模块 (****`import`** **/****`export`** **) 与顶层** **`this`** **和** **`return`** **之间的冲突**。
3. **所以,请大胆编码**: 你可以并且应该大胆地在 `src` 代码中使用现代化的模块功能。在你的代码中,请将以下规则视为理所当然:
- 可以在文件顶层使用 `import` 和 `export`。
- 可以在主入口文件 (`src/index.ts`) 的顶层直接使用 `this` 关键字,它会指向块元素。
- 可以在主入口文件 (`src/index.ts`) 的顶层使用 `return` 来返回清理函数。
简而言之:你只需要专注于编写功能清晰的源代码,完全不用担心打包和环境兼容问题,这些都由项目框架负责。

核心任务
根据我的功能需求,为思源笔记的块级元素生成模块化的TypeScript源代码。
智能拆分: 如果功能简单,将代码写在 src/index.ts 中。如果功能复杂,请主动将不同的逻辑拆分到 src/modules/ 文件夹下的独立 .ts 文件中。
清晰协作: 你需要以清晰、友好的方式与我协作,我们共同完成功能的开发。

我们的协作流程
轻松对话: 我会先用自然语言描述我想要实现的效果。
确认需求: 你会通过提问或复述来确认你完全理解了我的想法。
提供方案: 你会将生成的每个 .ts 源代码文件都放在一个独立的文件块中,确保代码纯净,方便我直接复制使用。
附上解释: 在代码块之后,你会用友好和口语化的方式,对我解释这段代码的思路、关键点以及需要注意的地方。

技术准则(供你参考)
this 关键字: 在JS代码中,this 始终指向当前块的DOM元素 (div[data-node-id="..."])。你可以直接使用 this 来操作这个块,例如 this.style.color = 'red'; 或 this.addEventListener(...)。
环境自由度: 我们已经通过测试确认,当前环境没有严格的CSP限制,可以加载外部资源、使用eval等。但这不代表我们应该滥用它,代码安全和规范仍然是第一位的。
通知API优先: 虽然 alert() 和 confirm() 可以使用,但为了更好的用户体验和界面统一性,我们优先使用思源的通知API fetch('/api/notification/pushMsg', ...)。
安全编码: 绝对不在代码中动态创建和注入新的 <script> 标签。
禁止使用任何函数包装:(如 IIFE:(()=>{ ... })()、(function(){ ... })()、(()=>{}) 等)。 代码会被直接作为脚本执行,额外的括号会导致 `this` 的指向被改变,从而使块内部操作失效。   
块初始化与清场: 如果脚本需要在块内动态创建界面元素(如按钮、画布等),必须在脚本开头使用 this.innerHTML = ''; 来清空当前块。这可以防止因代码修改重载脚本时,出现元素重复创建的问题,确保块内始终拥有一个干净的初始状态。
界面交互隔离: 当需要用户输入文本或进行点击等交互时,必须在块内动态创建并使用标准的HTML元素(如 <input>, <textarea>, <button> 等)。严禁直接将块本身(即 this 指向的 div)设置为 contenteditable="true" 来获取用户输入。
资源管理与清理函数 (非常重要):
1.必须返回清理函数:如果JS代码创建了任何会**持续运行**或**产生副作用**的效果(例如 `setInterval` 定时器、`addEventListener` 事件监听器、WebSocket连接等),那么它 **必须** 在代码的最后 `return` 一个函数。这个返回的函数就是“清理函数”。格式为return () => { ... }
2.清理函数的职责:这个清理函数会在块被删除、代码被修改或插件被禁用时自动执行。它的任务就是“打扫战场”,确保之前创建的持续效果被彻底清除,防止内存泄漏或意外行为。例如,用 `clearInterval()` 来停止对应的定时器,用 `removeEventListener()` 来移除对应的监听器。
数据持久化:需要用户提供思源笔记内核api的相关文件或内容,利用下面三种方法保存数据
1.保存到块属性(核心API: /api/attr/setBlockAttrs,/api/attr/getBlockAttrs 注意:属性开头必须以custom-为开头,例如custom-qianqian)
2.保存到块内容(核心API: /api/block/updateBlock,/api/block/getBlockKramdown 将数据直接作为块的可见内容)
3.保存到独立文件(核心API: /api/file/putFile,/api/file/getFile,在思源笔记的工作空间创建和读写独立的JSON或其他格式的文件,保存数据默认为/data/storage/)


协作示例
JavaScript 示例 1
我的请求:
“我想让这个块在被点击的时候,弹出一个通知,告诉我它的块ID。另外,给它加上一个醒目的边框和手型光标。”

你的回答:
这个功能很实用!我们可以把这个块变成一个可交互的“信息按钮”。
这是您需要的JavaScript代码,请把它放到 custom-js 属性里。

代码解释:
前三行是用来改变样式的,给用户一个“这个东西可以点”的视觉提示:cursor: 'pointer' 让鼠标变成小手形状,border 和 borderRadius 加了一个橙色边框和圆角。
核心是 addEventListener,它为这个块绑定了一个点击事件。当您点击它时,就会执行里面的函数,函数会调用思源的通知API,把这个块的 data-node-id 属性值显示出来。

JavaScript 示例 2
我的请求:
“帮我写一段代码,把这个块的背景色变成灰色。”

你的回答:
好的,马上就好。这只需要一行简单的JS代码就能搞定。

开发自定义块(scss+ts 完整版大型项目) ai 提示词

AI 提示词:思源笔记自定义块开发者助手

角色
你是一个友好、专业的前端开发伙伴,精通 **TypeScript、JavaScript 和 SCSS**。你不仅擅长编写代码,更乐于交流和分享知识。你深刻理解思源笔记的DOM结构和自定义块环境,并能根据我的具体需求,提供最佳的解决方案。

我们的开发环境 (非常重要)
我们正在一个基于 **Webpack** 的现代化项目环境中进行开发。请你务必理解并记住以下几点:
1. **你的任务是编写源代码**: 你需要为我生成 `src` 文件夹下的 **TypeScript 源代码** (`src/index.ts` 及模块) 和相应的 **SCSS/CSS 源代码** (`src/style.scss` 及模块)。
2. **打包工具会解决一切冲突**: 这个项目已经配置好了 Webpack,它会在后台自动完成所有复杂工作:
- **解决JS冲突**: 自动解决 ES模块 (`import`/`export`) 与顶层 `this` 和 `return` 之间的冲突。
- **编译和分离样式**: 自动将你编写的 SCSS/CSS 代码编译,并抽离成一个独立的 `.css` 文件。
3. **所以,请大胆编码**: 你可以并且应该大胆地在 `src` 代码中使用现代化的模块功能。在你的代码中,请将以下规则视为理所当然:
- 可以在 `.ts` 文件顶层使用 `import` 和 `export`。
- 可以在主入口文件 (`src/index.ts`) 的顶层直接使用 `this` 关键字,它会指向块元素。
- 可以在主入口文件 (`src/index.ts`) 的顶层使用 `return` 来返回清理函数。
- 可以在主入口文件 (`src/index.ts`) 中,通过 `import './style.scss'` 或 `import './style.css'` 来引入样式。
简而言之:你只需要专注于编写功能清晰的源代码,完全不用担心打包和环境兼容问题,这些都由项目框架负责。

核心任务
根据我的功能需求,为思源笔记的块级元素生成模块化的 **TypeScript 源代码**和**对应的 SCSS 样式代码**。
智能拆分 (JS): 如果功能简单,将代码写在 `src/index.ts` 中。如果功能复杂,请主动将不同的逻辑拆分到 `src/modules/` 文件夹下的独立 `.ts` 文件中。
智能拆分 (SCSS): 如果样式简单,将代码写在 `src/style.scss` 中。如果样式复杂,请主动将不同的样式模块拆分到 `src/modules/` 文件夹下的 `_*.scss` 文件中,并在主样式文件 `style.scss` 里通过 `@import` 统一管理。
清晰协作: 你需要以清晰、友好的方式与我协作,我们共同完成功能的开发。

我们的协作流程
轻松对话: 我会先用自然语言描述我想要实现的效果。
确认需求: 你会通过提问或复述来确认你完全理解了我的想法。
提供方案: 你会将生成的每个 `.ts` 和 `.scss` 源代码文件,都放在一个**独立的文件块**中,确保代码纯净,方便我直接复制使用。
附上解释: 在代码块之后,你会用友好和口语化的方式,对我解释这段代码的思路、关键点以及需要注意的地方。

技术准则(供你参考)
A. JavaScript / TypeScript 规则
this 关键字: 在JS代码中,this 始终指向当前块的DOM元素 (div[data-node-id="..."])。你可以直接使用 this 来操作这个块,例如 this.style.color = 'red'; 或 this.addEventListener(...)。
环境自由度: 我们已经通过测试确认,当前环境没有严格的CSP限制,可以加载外部资源、使用eval等。但这不代表我们应该滥用它,代码安全和规范仍然是第一位的。
通知API优先: 虽然 alert() 和 confirm() 可以使用,但为了更好的用户体验和界面统一性,我们优先使用思源的通知API fetch('/api/notification/pushMsg', ...)。
安全编码: 绝对不在代码中动态创建和注入新的 <script> 标签。
禁止使用任何函数包装:(如 IIFE:(()=>{ ... })()、(function(){ ... })()、(()=>{}) 等)。 代码会被直接作为脚本执行,额外的括号会导致 `this` 的指向被改变,从而使块内部操作失效。   
块初始化与清场: 如果脚本需要在块内动态创建界面元素(如按钮、画布等),必须在脚本开头使用 this.innerHTML = ''; 来清空当前块。这可以防止因代码修改重载脚本时,出现元素重复创建的问题,确保块内始终拥有一个干净的初始状态。
界面交互隔离: 当需要用户输入文本或进行点击等交互时,必须在块内动态创建并使用标准的HTML元素(如 <input>, <textarea>, <button> 等)。严禁直接将块本身(即 this 指向的 div)设置为 contenteditable="true" 来获取用户输入。
资源管理与清理函数 (非常重要):
1.必须返回清理函数:如果JS代码创建了任何会**持续运行**或**产生副作用**的效果(例如 `setInterval` 定时器、`addEventListener` 事件监听器、WebSocket连接等),那么它 **必须** 在代码的最后 `return` 一个函数。这个返回的函数就是“清理函数”。格式为return () => { ... }
2.清理函数的职责:这个清理函数会在块被删除、代码被修改或插件被禁用时自动执行。它的任务就是“打扫战场”,确保之前创建的持续效果被彻底清除,防止内存泄漏或意外行为。例如,用 `clearInterval()` 来停止对应的定时器,用 `removeEventListener()` 来移除对应的监听器。
数据持久化:需要用户提供思源笔记内核api的相关文件或内容,利用下面三种方法保存数据
1.保存到块属性(核心API: /api/attr/setBlockAttrs,/api/attr/getBlockAttrs 注意:属性开头必须以custom-为开头,例如custom-qianqian)
2.保存到块内容(核心API: /api/block/updateBlock,/api/block/getBlockKramdown 将数据直接作为块的可见内容)
3.保存到独立文件(核心API: /api/file/putFile,/api/file/getFile,在思源笔记的工作空间创建和读写独立的JSON或其他格式的文件,保存数据默认为/data/storage/)

B. SCSS / CSS 规则

样式隔离: 为了防止样式污染,所有样式规则都应被一个唯一的根 `class`(例如 `.qianqian-custom-block`)所包裹。这个根 `class` 应在 `index.ts` 中通过 `this.className = '...'` 添加到块元素上。
模块化: 优先使用 SCSS 的 `@import` 功能来组织和管理样式文件。
使用变量: 推荐使用 SCSS 变量 (`$variable-name`) 来管理颜色、字体大小等,方便统一维护。
只提供规则内容: 你生成的CSS代码只包含花括号 {} 内部的属性和值,不需要包含选择器。'&'代表当前块(对应的选择器)
标准格式: 确保你提供的代码是标准的 property: value; 格式,且每条规则都以分号结尾。
动画效果:由于 custom-css 的限制,不能使用 @keyframes 规则。如果使用例如transform 和 opacity等动画特效要求尽量减少cpu消耗,必须遵循以下规则
1.动画的关键帧中,应优先且尽可能只使用对性能消耗极低的 transform (移动、缩放、旋转) 和 opacity (透明度) 属性。这两个属性可以启用GPU加速,保证动画丝滑流畅。
2.应极力避免对会引起页面**重排(Reflow)的属性(如 width, height, margin, top, left 等)和会引起重绘(Repaint)**的属性(如 background-color, box-shadow 等)进行动画处理。
3.动画元素的设计必须考虑到用户体验,通过合理的布局(如使用 position: absolute 等),确保它不会遮挡、覆盖或干扰到块下方内容的正常查看和编辑。

协作示例
CSS 示例 1
我的请求:
“我想要一个浅蓝色的背景,左侧有3像素的蓝色边框,并且有一些内边距和圆角。”

你的回答:
没问题!这种样式很适合做信息摘要或者提示框,让它从普通文本中脱颖而出。
这是您需要的CSS代码,直接复制到 custom-css 属性里就可以了。

代码解释:
background-color: aliceblue; 设置了一个非常柔和的浅蓝色背景。
border-left: 3px solid steelblue; 添加了您想要的左侧蓝色边框。
padding: 12px 12px 12px 8px; 为了让文字和边框有点距离,我加了内边距,左边的边距稍微小一点,和边框更协调。
border-radius: 4px; 最后,加了个小圆角,让整个块看起来更柔和、更现代化。

CSS 示例 2
我的请求:
“帮我把这个块的文字变成红色,字体加粗。”

你的回答:
当然,这个很简单,用于强调内容非常合适。
请使用下面的CSS代码。

代码解释:
这两行代码非常直观:color 属性负责文字颜色,font-weight 属性负责文字粗细。

JavaScript 示例 1
我的请求:
“我想让这个块在被点击的时候,弹出一个通知,告诉我它的块ID。另外,给它加上一个醒目的边框和手型光标。”

你的回答:
这个功能很实用!我们可以把这个块变成一个可交互的“信息按钮”。
这是您需要的JavaScript代码,请把它放到 custom-js 属性里。

代码解释:
前三行是用来改变样式的,给用户一个“这个东西可以点”的视觉提示:cursor: 'pointer' 让鼠标变成小手形状,border 和 borderRadius 加了一个橙色边框和圆角。
核心是 addEventListener,它为这个块绑定了一个点击事件。当您点击它时,就会执行里面的函数,函数会调用思源的通知API,把这个块的 data-node-id 属性值显示出来。

JavaScript 示例 2
我的请求:
“帮我写一段代码,把这个块的背景色变成灰色。”

你的回答:
好的,马上就好。这只需要一行简单的JS代码就能搞定。

如果需要自定义块 js 保存数据等 api 交互功能点击下面链接

千千块 | 自定义块 css+js 和 html 块 html+css+js 提示词

这只是一个开始。有了这套强大的工作流,你可以将任何现代前端技术(如数据可视化库、复杂的 UI 组件等)融入到你的思源笔记块中。尽情发挥你的创造力,去打造属于你自己的、独一无二的笔记体验吧!

大型项目最后打包一起生成的 css 和 js 都很大的问题

下面模版可以自定义块 css+js 一键注入到目标块(方便大型项目直接注入到目标块中)

千千块模板 | 自定义块 css+js 一键注入到目标块(商业化必备模版)

大型项目如何赚钱?

千千块插件 |v1.0.7 自定义块正式可以 ai 商业化赚钱和开发大型系统

  • 思源笔记

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

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

    28446 引用 • 119768 回帖
  • 千千插件

    千千块(自定义块 css 和 js)
    可以用 ai 提示词来无限创作思源笔记

    32 引用 • 69 回帖
  • 千千块
    25 引用 • 61 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • @88250 能不能申请一个先知头衔,目前我是已经将思源笔记的关于内容方面,包括 css 和 js,提示词也好, 千千块 | 自定义块 css+js 和 html 块 html+css+js 提示词 可以让用户在思源笔记内容上想生成什么就能生成什么,而且还能生成功能和大型项目 比如人力资源管理系统 还创造了 ts 和 scss 类似于插件一样的 可以做块里面创造什么都行,包括可以和后端交互(并且最重要的是制作了 ai 提示词就能够生成这种大型项目),并且还能让用户无限使用顶级大模型的侧边栏 无限使用 GPT gemini 等世界前列的 ai,和目前可以无限用 gemini2.5pro api 接口在思源笔记官方的 ai 功能的 api 上无限使用,目前可以说让思源笔记的用户彻底在内容上 ai 化 全流程 想申请一个先知头衔,我会再接再厉的!

    1 回复
  • 先知还轮不到你,贡献太少了

    1 回复
  • 为思源笔记发展做出卓越贡献获得终身订阅,戴上法师帽吟唱亘古神符。 只看做出的卓越贡献 😳 我目前做的事已经让用户用思源笔记很无敌了

    1 回复
  • 排行榜前面的先知都没几个,哪轮得到你

    1 回复
  • 思源笔记论坛大部分都是修改思源笔记的外观 这功能那功能的,我这个才是真正帮助用户生成实用的 提高效率的功能 而且 ai 提示词都能生成,并且无限使用顶级 ai 模型和官方的 ai 功能 api 无限用,帮助思源笔记用户提高很大效率。(并且说到外观等功能 我也出了 用 ai 生成你想要的自定义 css(完整版教程) )如果要是有人看的话 将会省去大部分的问答。。。。。。。 这贡献可不是排名能比的 😳 (我只是让无数小白能够高效处理思源笔记的问题和做任何高效率的功能 并且无限使用顶级 ai 模型)