Coco-AI 支持嵌入,让你的网站拥有 AI 搜索力

news2025/5/19 5:47:12

在之前的实践中,我们已经成功地把 Hexo、Hugo 等静态博客和 Coco-AI 检索系统打通了:只要完成向量化索引,就可以通过客户端问答界面实现基于内容的智能检索。

这一层已经很好用了,但总觉得少了点什么——

比如用户还得专门打开一个“AI 客户端”,有点割裂。那能不能像搜索框一样,直接把问答体验嵌进网页里,做到随时可问,实时返回,就像 ChatGPT 驻扎在你自己的网站里?

答案是可以的。从 Coco-AI v0.3 开始,我们终于可以像调用前端组件一样,将搜索框直接嵌入到网页中,而且配置极简,几乎零门槛。


🧱 零配置启动:Coco 搜索框长这样

实际上,哪怕你完全不改配置,直接使用默认参数,就能跑出一个干净、简洁的 AI 搜索框:

image-20250403211609047

它默认采用悬浮式设计,右下角一个小 logo,点击之后弹出一个输入框,你可以直接输入问题,系统自动返回答案。

对于很多不熟前端的朋友来说,这个“即插即用”的特性真的太香了。


🚀 一步到位:HTML 页面嵌入组件

当然,如果你有自己的网页结构,也可以通过标准的 ES Module 写法,把组件嵌入到指定位置。

下面是一个最小 HTML 示例:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <title>搜索组件嵌入示例</title>
  <style>
    body {
      font-family: sans-serif;
      padding: 2rem;
    }
    #searchbox {
      margin-top: 20px;
      border: 1px solid #ccc;
      padding: 16px;
      border-radius: 8px;
    }
  </style>
</head>
<body>
  <h1>欢迎使用 Cloudsmithy 搜索组件</h1>
  <p>下面是通过 ES Module 引入的搜索框:</p>

  <div id="searchbox"></div>

  <script type="module">
    import { searchbox } from "http://localhost:9000/integration/cvmhvjl92jog2dokvsd0/widget";
    searchbox({
      container: "#searchbox"
    });
  </script>
</body>
</html>

✅ 总结一句话:
只要在页面里加一个 div,然后调用 searchbox(),AI 搜索就能跑起来。


🧪 实测效果:Live Server 本地运行

为了确认效果,我用 VS Code 的 Live Server 插件本地打开这个 HTML 文件,页面加载后就能看到组件成功加载,完全不需要编译打包或插件支持:

image-20250403211339642

搜索框组件会自动初始化,可以立即输入问题,体验自然语言问答。


🌀 从 Hexo 编译失败,到想到油猴

本来我打算把这个搜索框组件嵌到 Hexo 博客中,想法很简单:直接在页面模板里引入这个模块。

结果 Hexo 的构建流程不太配合:

  • 没法直接在页面里用 import
  • 改动主题文件构建后会被覆盖;
  • 找不到原始 HTML,很多逻辑是动态拼装的;

这让我意识到:有时候,静态博客并不是一个容易动手脚的地方。

于是我换了个思路:干脆用油猴脚本直接“外挂”到页面里。


🐵 为什么选 Tampermonkey?

✅ 优点:

  • 无需改动原站源码;
  • 能在任意网页上注入组件,连别人家的站也行;
  • 适合自己内测、小范围使用。

⚠️ 缺点:

  • 需要用户安装 Tampermonkey 插件;
  • 某些网站的 CSP 策略可能会阻止模块加载。

image-20250403212234757


🧩 油猴脚本完整代码

这是我用的实际代码,只做了最基本的挂载和模块加载操作:

// ==UserScript==
// @name         Searchbox Embedder
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  在任意网页中注入 searchbox 小部件
// @author       You
// @match        *://*/*
// @grant        none
// @run-at       document-end
// ==/UserScript==

(function () {
  'use strict';

  // 创建搜索框容器
  const searchboxDiv = document.createElement('div');
  searchboxDiv.id = 'searchbox';
  document.body.appendChild(searchboxDiv);

  // 插入模块化脚本
  const script = document.createElement('script');
  script.type = 'module';
  script.textContent = `
    import { searchbox } from "http://localhost:9000/integration/cvmhvjl92jog2dokvsd0/widget";
    searchbox({ container: "#searchbox" });
  `;
  document.body.appendChild(script);
})();

📸 最终效果:Coco 搜索框上线!

下面这个截图就是油猴脚本挂载组件后的样子,运行脚本后,你会在网页右下角看到一个熟悉的 Coco logo,点击它,就能唤出对话框:

image-20250403212124062

你可以输入问题,比如“这篇博客在哪提到 RAG?”系统会自动返回你想要的内容。对于博客站长来说,这种方式几乎等同于给读者配了个“专属智能客服”。


🎯 总结一下,推荐给谁?

不管你是:

  • 做个人博客的开发者;
  • 运营公司知识库或文档站;
  • 想给现有网页加点 AI “魔法”;

Coco-AI 的嵌入式搜索组件,都是一个轻量又实用的方案。

你可以选择两种方式:

嵌入方式适用场景优点限制
HTML 原生嵌入可控部署的网站、博客模板不依赖任何插件、原生体验需要动源码、构建系统支持模块化
Tampermonkey 插件自测网页、不可修改站点快速部署、无需改网页需要浏览器插件、不适合普通用户

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2327967.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TRDI 公司的RiverPro 和 RioPro ADCP 用户指南

TRDI 公司 RiverPro 和 RioPro ADCP 用户指南 简介第一章 - 概述第二章 - 安装第三章 - 采集数据第四章 - 维护第五章 - 测试RIVERPRO/RIOPRO第六章 - 故障排除第七章 - 将系统返回TRDI进行维修第八章 - 规格第九章 - 命令第十章 - 输出数据格式附录A-合规通知首次完整翻译《Ri…

OpenCV 图形API(11)对图像进行掩码操作的函数mask()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 描述 对矩阵应用掩码。 该函数mask设置来自给定矩阵的值&#xff0c;如果掩码矩阵中对应的像素值设为true&#xff0c;否则将矩阵的值设为0。 支持的源矩阵…

使用C#写的一个Kafka的使用工具

由于offset不支持通过界面推送数据&#xff0c;所以我写了一个kafka的连接工具&#xff0c;能够直接从界面推送数据&#xff0c;方便使用。由于使用的是C#写的&#xff0c;所以比offset要流畅的多。 1、数据源连接 2、获取集群的topic 3、点击获取数据能够获取最新的100条数…

【通知】STM32MP157驱动开发课程全新升级!零基础入门嵌入式Linux驱动,掌握底层开发核心技能!

在嵌入式Linux系统开发中&#xff0c;驱动程序开发是一项关键技术&#xff0c;它作为硬件与软件之间的桥梁&#xff0c;实现了操作系统对硬件设备的控制。相较于嵌入式Linux应用开发&#xff0c;驱动开发由于涉及底层硬件且抽象程度较高&#xff0c;往往让初学者感到难度较大。…

飞浆PaddlePaddle 猫狗数据大战

猫狗数据大战 1 数据集的准备以及处理操作1.1 数据集1.2 文件解压操作&#xff08;python&#xff09; 1.3 数据的分类1.4 创建训练集和测试集 2 网络构建CNN版本--DeepID 人脸识别网络结构DeepID 与 CNN 网络结构的差异 3 深度学习模型训练和推理的核心设置4 制图5 训练6 预测…

使用高德api实现天气查询

创建应用获取 Key 天气查询-基础 API 文档-开发指南-Web服务 API | 高德地图API 代码编写 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-wid…

Could not find artifact com.microsoft.sqlserver:sqljdbc4:jar:4.0 in central

具体错误 [ERROR] Failed to execute goal on project datalink-resource: Could not resolve dependencies for project com.leon.datalink:datalink-resource:jar:1.0.0: Could not find artifact com.microsoft.sqlserver:sqljdbc4:jar:4.0 in central (https://repo.maven…

Express学习笔记(三)——使用 Express 写接口

目录 1. 创建基本的服务器 2. 创建 API 路由模块 3. 编写 GET 接口 4. 编写 POST 接口 5. CORS 跨域资源共享 5.1 接口的跨域问题 5.2 使用 cors 中间件解决跨域问题 5.3 什么是 CORS 5.4 CORS 的注意事项 5.5 CORS 响应头部 - Access-Control-Allow-Origin 5.6 COR…

【HarmonyOS Next之旅】DevEco Studio使用指南(十)

目录 1 -> Optimize Imports功能 2 -> 父/子类快速跳转 3 -> 查看接口/类的层次结构 4 -> 代码自动补全 1 -> Optimize Imports功能 使用编辑器提供的Optimize Imports&#xff0c;可以快速清除未使用的import&#xff0c;并根据设置的规则对import进行合并…

java并发编程-并发容器

并发容器 CopyOnWriteArrayListCopyOnWriteArraySetConcurrentHashMapConcurrentSkipListMap迭代器的fail-fast与fail-safe机制应用场景 CopyOnWriteArrayList 线程不安全容器&#xff1a;ArrayList代替Vector、synchronizedList适用于读多写少的场景&#xff0c;对读操作不加…

PPT助手:一款集计时、远程控制与多屏切换于一身的PPT辅助工具

PPT助手&#xff1a;一款集计时、远程控制与多屏切换于一身的PPT辅助工具 &#x1f4dd;&#x1f3a4; 在现代化的演讲和演示中&#xff0c;如何高效地控制PPT进程、保证展示的流畅性与精准性&#xff0c;成为了每个演讲者必须面对的挑战。无论是商务汇报、学术演讲&#xff0…

大模型应用初学指南

随着人工智能技术的快速发展&#xff0c;检索增强生成&#xff08;RAG&#xff09;作为一种结合检索与生成的创新技术&#xff0c;正在重新定义信息检索的方式&#xff0c;RAG 的核心原理及其在实际应用中的挑战与解决方案&#xff0c;通用大模型在知识局限性、幻觉问题和数据安…

如何通过管理系统提升团队协作效率

在现代企业管理中&#xff0c;团队协作效率的高低直接关系到企业的竞争力和运营效率。随着信息技术的不断发展&#xff0c;管理系统作为提升团队协作效率的重要工具&#xff0c;逐渐受到企业的重视。本文将深入探讨如何通过管理系统提升团队协作效率&#xff0c;为企业提供实用…

云手机如何防止设备指纹被篡改

云手机如何防止设备指纹被篡改 云手机作为虚拟化设备&#xff0c;其设备指纹的防篡改能力直接关系到账户安全、反欺诈和隐私保护。以下以亚矩阵云手机为例&#xff0c;讲解云手机防止设备指纹被篡改的核心技术及实现方式&#xff1a; 系统层加固&#xff1a;硬件级安全防护 1…

XT1870 同步升压 DC-DC 变换器

1、 产品概述 XT1870 系列产品是一款低功耗、高效率、低纹波、工 作频率高的 PFM 控制升压 DC-DC 变换器。 XT1870 系列产品仅需要 3 个外部元器 , 即可完成低输 入的电池电压输入。 2、用途 数码相机、电子词典 LED 手电筒、 LED 灯 血压计、MP3 、遥控玩具 …

seaweedfs分布式文件系统

seaweedfs https://github.com/seaweedfs/seaweedfs.git go mod tidy go -o bin ./… seaweed占不支持smb服务&#xff0c;只能用fuse的方式mount到本地文件系统 weed master 默认端口&#xff1a;9333&#xff0c;支持浏览器访问 weed volume 默认端口&#xff1a;8080 weed …

Spring Boot后端开发全攻略:核心概念与实战指南

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家、全栈领域优质创作者、高级开发工程师、高级信息系统项目管理师、系统架构师&#xff0c;数学与应用数学专业&#xff0c;10年以上多种混合语言开发经验&#xff0c;从事DICOM医学影像开发领域多年&#xff0c;熟悉DICOM协议及…

通过 Markdown 改进 RAG 文档处理

通过 Markdown 改进 RAG 文档处理 作者&#xff1a;Tableau 原文地址&#xff1a;https://zhuanlan.zhihu.com/p/29139791931 通过 Markdown 改进 RAG 文档处理https://mp.weixin.qq.com/s/LOBOKNA71dANXHuwxe7yxw 如何将 PDF 转换为 Markdown 以获得更好的 LLM RAG 结果 Mar…

高速电路 PCB 设计要点一

3 高速电路 PCB 设计要点 3.1 PCB设计与信号完整性 随着电子技术的发展&#xff0c;电路的规模越来越大&#xff0c;单个器件集成的功能越来越多&#xff0c;速率越来越高&#xff0c;而器件的尺寸越来越小。由于器件尺寸的减小&#xff0c;器件引脚信号变化沿的速率变得越来…

【Centos】centos7内核升级-亲测有效

相关资源 通过网盘分享的文件&#xff1a;脚本升级 链接: https://pan.baidu.com/s/1yrCnflT-xWhAPVQRx8_YUg?pwd52xy 提取码: 52xy –来自百度网盘超级会员v5的分享 使用教程 将脚本文件上传到服务器的一个目录 执行更新命令 yum install -y linux-firmware执行脚本即可 …