Dify Web 前端二次开发(隐藏探索功能 + 替换 Logo)

核心修改内容

  1. 隐藏导航栏「探索」功能(图标 + 文字按钮);
  2. 将默认 Dify Logo 替换为自定义 FDAI Logo(PNG 格式)。

(一)隐藏「探索」功能完整过程

1. 定位目标组件

探索功能对应的组件文件路径:web/app/components/header/explore-nav/index.tsx(组件名:ExploreNav),该组件被嵌套在 Header 组件中渲染,无需修改布局文件 app/(commonlayout)/layout.tsx

2. 首次尝试:仅删除图标(未彻底隐藏)
  • 操作:删除组件内图标渲染代码 { activated ? <RiPlanetFill /> : <RiPlanetLine /> },并移除对应图标导入;
  • 结果:仅图标消失,「探索」文字按钮仍存在,未达到彻底隐藏需求。
3. 二次尝试:返回 null 报错
  • 操作:将 ExploreNav 组件的返回值改为 return null,注释原有 Link 渲染代码;
  • 结果:页面报 Uncaught SyntaxError(注释代码时残留未闭合的引号 / 括号,导致语法不完整)、ChunkLoadError(编译缓存异常),服务无法正常加载。
4. 最终方案:返回空片段(无语法错误)
  • 操作:直接替换 ExploreNav 组件代码,保留必要变量定义,返回 <></> 空片段,同时清理图标、Link 等无用导入;
  • 结果:「探索」功能(图标 + 文字)彻底隐藏,无语法错误。

核心修改后代码:tsx

'use client' import { useTranslation } from 'react-i18next' import { useSelectedLayoutSegment } from 'next/navigation' import classNames from '@/utils/classnames' type ExploreNavProps = { className?: string } const ExploreNav = ({ className }: ExploreNavProps) => { const { t } = useTranslation() const selectedSegment = useSelectedLayoutSegment() const activated = selectedSegment === 'explore' return <></> // 空片段不渲染任何内容 } export default ExploreNav 

(二)替换 Logo 完整过程

  • 操作:将自定义 FDAI Logo(PNG 格式)放入项目静态资源目录 public/logo/,文件命名为 FDAI.png
  • 路径说明:public 是 Next.js 默认静态资源目录,public/logo/FDAI.png 可通过 /logo/FDAI.png 直接访问。
2. 定位 Logo 组件

Logo 对应的组件文件路径:web/app/components/header/logo/index.tsx(组件名:DifyLogo)。

3. 修改组件配置(核心步骤)
  • 操作 1:更新 Logo 路径映射,替换为自定义 PNG 路径;
  • 操作 2:保留原尺寸配置(适配 48x22 比例),修改 alt 文本为 FDAI logo

核心修改后代码:tsx

'use client' import type { FC } from 'react' import classNames from '@/utils/classnames' import useTheme from '@/hooks/use-theme' import { basePath } from '@/utils/var' export type LogoStyle = 'default' | 'monochromeWhite' export type LogoSize = 'large' | 'medium' | 'small' // 替换为自定义 Logo 路径 export const logoPathMap: Record<LogoStyle, string> = { default: '/logo/FDAI.png', monochromeWhite: '/logo/FDAI.png', // 无白色版则复用同一文件 } // 保留原尺寸(适配 48x22 比例) export const logoSizeMap: Record<LogoSize, string> = { large: 'w-16 h-7', medium: 'w-12 h-[22px]', small: 'w-9 h-4', } type DifyLogoProps = { style?: LogoStyle; size?: LogoSize; className?: string } const DifyLogo: FC<DifyLogoProps> = ({, size = 'medium', className, }) => { const { theme } = useTheme() const themedStyle = (theme === 'dark' && style === 'default') ? 'monochromeWhite' : style return ( <img src={`${basePath}${logoPathMap[themedStyle]}`} className={classNames('block object-contain', logoSizeMap[size], className)} alt='FDAI logo' // 更新 Logo 描述 /> ) } export default DifyLogo 
4. 解决编译报错(后续处理)
  • 问题:修改后页面报语法错误和缓存加载失败;
  • 操作:停止前端服务 → 删除 web/.next 编译缓存目录 → 重新启动服务(npm run dev);
  • 结果:Logo 成功替换,无报错。

二、修改过程中遇到的问题及解决方案

(一)隐藏「探索」功能相关问题

  1. 仅删除图标后,「探索」文字按钮仍存在
    • 根本原因:只移除了图标渲染代码,未隐藏整个 ExploreNav 组件;
    • 解决方案:让 ExploreNav 组件返回 <></> 空片段,不渲染任何内容,彻底隐藏组件。
  2. 返回 null 后报 Uncaught SyntaxError
    • 根本原因:注释原有代码时残留未闭合的引号、括号,导致代码语法不完整;
    • 解决方案:直接替换为无多余注释的完整代码,返回空片段而非 null,同时清理图标、Link 等无用导入,避免语法残留。
  3. 报 ChunkLoadError: Loading chunk app/layout failed
    • 根本原因:组件语法错误导致 Next.js 编译缓存异常,加载缓存文件失败;
    • 解决方案:停止前端服务,手动删除 web/.next 缓存目录,重新启动服务,清除异常缓存。

(二)替换 Logo 相关问题

  1. Logo 未显示,报资源加载失败
    • 根本原因:要么 PNG 文件路径与代码配置不一致,要么文件名大小写不匹配(如 fdai.png 与 FDAI.png 区分大小写);
    • 解决方案:确认 public/logo/FDAI.png 文件存在,且代码中 logoPathMap 配置的路径与文件名完全一致(含大小写)。
  2. Logo 显示拉伸 / 变形
    • 根本原因:自定义 PNG 尺寸比例与原组件配置(适配 48x22 比例)不匹配;
    • 解决方案:调整 logoSizeMap 中的 w-xxx h-xxx 数值,保持宽高比与自定义 PNG 一致(例如 medium: 'w-14 h-[24px]')。
  3. 修改后仍显示原 Dify Logo
    • 根本原因:Next.js 开发模式热重载未生效,残留旧 Logo 缓存;
    • 解决方案:手动刷新浏览器页面,或重启前端服务,强制加载新配置。
  4. 报 preloaded with link preload was not used within a few seconds 警告
    • 根本原因:静态资源预加载配置与实际使用不匹配,属于浏览器资源加载警告,非功能错误;
    • 解决方案:无需额外处理,不影响 Logo 显示和功能使用;若需消除警告,可检查 layout.tsx 中预加载标签的属性配置。

(三)通用编译 / 运行问题

  1. MouseEvent.mozInputSource is deprecated 警告
    • 根本原因:浏览器 API 兼容问题,Next.js 依赖的底层库使用了过时 API;
    • 解决方案:无需处理,不影响功能正常运行;后续可通过升级 Next.js 版本修复该兼容警告。
  2. 编译后服务启动缓慢或卡顿
    • 根本原因:修改组件后未清理缓存,导致编译产物冗余;
    • 解决方案:定期清理 web/.next 缓存目录,重启服务时避免残留旧编译文件。

欢迎评论私信讨论Dify相关的问题,需要源码私我

Read more

手把手教你使用 Faster-Whisper 实时语音输入转文本,本地部署教程

手把手教你使用 Faster-Whisper 实时语音输入转文本,本地部署教程

文章目录 * 前言 * 一、安装环境 * 二、使用步骤 * 1.下载模型 * 2.实时录音转文本脚本 * 3.报错解决方法 * 总结 前言 要想实现像豆包、微信等一样的语音输入功能,通常有两种主流方案:云端 API(轻量、准确度极高)和 本地模型(免费、隐私、无需联网)。由于目前开发的系统需要添加一个语音识别功能,刚好记录一下使用 Faster-Whisper 实时语音输入转文本。Faster-Whisper官网地址链接: Faster-Whisper官网地址 复现成功如下图所示,请看下文教程就能部署本地实时语音输入转文本模型: 电脑有显卡的话可以参考下面这篇文章安装 cuda 和 cudnn cuda和cudnn的安装教程: cuda和cudnn的安装教程(全网最详细保姆级教程) 一、安装环境 在你的虚拟环境安装 faster-whisper,命令如下: pip install faster-whisper 安装录音库

Cogito-v1-preview-llama-3B部署教程:免配置镜像快速上手Ollama环境

Cogito-v1-preview-llama-3B部署教程:免配置镜像快速上手Ollama环境 1. 什么是Cogito v1预览版模型 Cogito v1预览版是Deep Cogito推出的混合推理模型系列,这个3B参数的模型在大多数标准基准测试中都表现出色,超越了同等规模的其他开源模型。无论是LLaMA、DeepSeek还是Qwen等知名模型的同类版本,Cogito v1都展现出了更强的能力。 Cogito模型是经过指令调优的生成式模型,采用文本输入和文本输出的方式。最重要的是,所有模型都以开放许可发布,这意味着你可以放心地在商业项目中使用它们。 这个模型的独特之处在于它的混合推理能力。它既可以像标准大语言模型那样直接回答问题,也可以在回答前进行自我反思和推理,这种双重模式让它能够处理更复杂的问题场景。 2. 模型特点与技术优势 2.1 核心技术创新 Cogito模型采用了迭代蒸馏和放大(IDA)训练策略,这是一种通过迭代自我改进来实现智能对齐的高效方法。简单来说,就是让模型在学习过程中不断优化自己,变得越来越聪明。 模型在多个关键领域都进行了专门优化:编程代

ChatGLM3-6B-128K开箱体验:Ollama三步骤搭建AI写作助手

ChatGLM3-6B-128K开箱体验:Ollama三步骤搭建AI写作助手 你是不是也遇到过这些场景: 写周报卡在第一句,改了八遍还是像流水账; 给客户写产品介绍,翻来覆去就那几句话,缺乏专业感; 整理会议纪要时,录音转文字堆成山,却不知从哪下手提炼重点; 甚至只是想给朋友圈配一段有温度的文案,敲了半天键盘又全删掉…… 别急——这次不用装环境、不配显卡、不调参数。我用一台普通办公笔记本(16G内存+集显),三步完成部署,5分钟启动一个真正能帮上忙的AI写作助手。它不是玩具模型,而是刚发布的长文本增强版:ChatGLM3-6B-128K,原生支持最长128K上下文——相当于一口气读完一本《三体》全书再帮你写续章。 这不是概念演示,是我在真实写作流中反复验证过的落地方案。下面带你从零开始,亲手搭起属于你的轻量级AI写作中枢。 1. 为什么选ChatGLM3-6B-128K?不只是“更长”那么简单 很多人看到“128K”第一反应是:“哦,能处理更长文本”。但真正用起来你会发现,它的价值远不止于此。我们拆开来看它和普通6B模型的本质差异: 1.1 长文本≠堆字数,

文心一言开源版部署及多维度测评实例

文心一言开源版部署及多维度测评实例

文章目录 * 第一章 文心一言开源模型简介 * 第二章 模型性能深度实测 * 2.1 通用能力基准测试 * 2.1.1 文本生成质量 * 2.1.2 数学推理能力 * 2.2 极端场景压力测试 * 2.2.1 高并发性能 * 2.2.2 长上下文记忆 * 第三章 中文特色能力解析 * 3.1.2 文化特定理解 * 3.2 行业术语处理 * 3.2.1 法律文书解析 * 3.2.2 医疗报告生成 * 第四章 开源生态建设评估 * 4.1 模型可扩展性验证 * 4.