好消息,好消息,前端可以使用免费的ai模型构建一个ai聊天会话了

前言

前往openrouter ai申请一个免费的 key,然后使用ew-chat我写的这个ai聊天,就可以完成一个聊天会话网页。

在线地址

在线地址由于没有api_key,所以询问问题会报错。

效果如下图所示:

聊天会话的数据都使用永久会话存储在本地,以下是这个聊天会话的详细功能介绍。

说明:这个项目是使用trae编辑器帮忙编写,然后本人再修补一些trae处理不了的问题完成的。

功能分析

这个聊天会话包含了多个功能。

  1. 多语言切换
  2. 主题切换,包含深色和浅色2种主题模式
  3. 下载ai回答记录。
  4. 可以刷新回答,也可以停止会话。
  5. 上传文件并发送。
  6. 新增会话,编辑会话名字,删除会话,清除历史会话等。
  7. 内容渲染基于markdown,包含代码高亮,复制等功能。
  8. 响应式网站。

技术栈

  1. highlight.js来实现代码高亮
  2. ew-message消息提示框插件
  3. ew-responsive-store实现永久会话存储
  4. marked来实现内容渲染

具体功能

具体功能如下图所示:

核心api原理

核心api请求主要是如下这一段代码。

ts 复制代码
const response = await fetch('https://openrouter.ai/api/v1/chat/completions', {
    method: 'POST',
    headers: {
                'Authorization': `Bearer ${API_KEY}`,
                'Content-Type': 'application/json'
    },
    body: JSON.stringify({
        model: MODEL,
        messages: chats.value[chatId].messages.map(msg => ({
            role: msg.role,
            content: msg.content
        })),
        stream: true
    })
});

可以看到我们只要申请了key,就可以使用这个接口,然后得到ai回答的数据,我们通过fetch向openrouter ai发送请求就行了。

感兴趣的可以看看源码,自行下载下来体验吧。如果觉得有用,希望不吝啬点赞收藏并给个star。

相关推荐
前端毕业班2 小时前
uni-app 小程序样式隔离实践指南和原理分析
前端·javascript·vue.js
仿生狮子2 小时前
🎼 从文本到交互界面——GenUI 的中庸之道
前端·vue.js·markdown
用户841794814564 小时前
vxe-gantt 甘特图在 Nuxt 中的集成与使用
vue.js
喵了几个咪4 小时前
AI重构软件开发范式:框架与脚手架为何仍是生产级开发的刚需?
vue.js·人工智能·react.js·重构·golang·ai编程
lpd_lt7 小时前
服务端类vue等页面AI测试方向
前端·vue.js·人工智能
橘子味的冰淇淋~7 小时前
优化前端性能之从“全局引入”改为“按需引入”
前端·javascript·vue.js
Vennn7 小时前
Android自动化:使用 Web 方式实现某音未读消息检查与采集
前端·javascript·vue.js
皮皮大人8 小时前
Vue 3 响应式内核完全解密:reactive & effect 与 Vue 2 Watcher 史诗对决
前端·vue.js
暗中讨饭xdm9 小时前
立体echarts柱状图咋做
前端·vue.js·echarts
w_t_y_y9 小时前
vue父子组件通信(一)父子调用和通信(2)VUE3
前端·javascript·vue.js