<?xml version="1.0" encoding="UTF-8"?><rss xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title><![CDATA[vaebe blog | 开发者]]></title><description><![CDATA[我是 Vaebe，一名全栈开发者，专注于前端技术。我的主要技术栈是 Vue 及其全家桶，目前也在使用 React 来构建项目，比如这个博客，它使用 Next.js。]]></description><link>https://blog.vaebe.cn/</link><image><url>https://blog.vaebe.cn//og/opengraph-image.png</url><title>vaebe blog | 开发者</title><link>https://blog.vaebe.cn/</link></image><generator>RSS for Node</generator><lastBuildDate>Wed, 22 Apr 2026 14:36:36 GMT</lastBuildDate><atom:link href="https://blog.vaebe.cn//feed.xml" rel="self" type="application/rss+xml"/><language><![CDATA[zh-CN]]></language><item><title><![CDATA[Nuxt3 与官网 SEO：从 TDK 配置到搜索引擎收录]]></title><description><![CDATA[使用 Nuxt3 进行官网 SEO 优化，涵盖 TDK 配置、sitemap/robots 生成、OgImage 自动创建，以及 Google、Bing 站点提交收录全流程。]]></description><link>https://blog.vaebe.cn//article/7605419006683152426</link><guid isPermaLink="false">7605419006683152426</guid><pubDate>Thu, 12 Feb 2026 05:59:46 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/79ba46d302cc42398ba1fbe7d8e904f2~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=DAVni6Dcr%2BlidJXmkzCeI9MS7C0%3D" length="0" type="false"/></item><item><title><![CDATA[优化使用 Nuxt3 开发的官网首页，秒开！]]></title><description><![CDATA[看我如何优化nuxt3 开发的官网，首先排查加载慢的原因，然后通过对应的优化手段让加载速度起飞，比如开启 http2、压缩图片、延迟加载字体、静态文件上 cdn]]></description><link>https://blog.vaebe.cn//article/7605448246995910697</link><guid isPermaLink="false">7605448246995910697</guid><pubDate>Thu, 12 Feb 2026 03:36:01 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/9e4e08001fe74cf2a401b5cf2405b092~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=lGPhSdX82c02Y9X%2BWVI441ekOm0%3D" length="0" type="false"/></item><item><title><![CDATA[Git提交信息太乱？AI一键美化！一行命令拯救你的项目历史🚀]]></title><description><![CDATA[git-rewrite-commits 用 AI 自动重写杂乱的 Git 提交信息。支持 Ollama 本地或云端模型，只需一行命令，即可规范化整个提交历史，再也不用手动修改！]]></description><link>https://blog.vaebe.cn//article/7581428845683179563</link><guid isPermaLink="false">7581428845683179563</guid><pubDate>Tue, 09 Dec 2025 07:35:54 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/3af3c468ef7b4efbab430b830fd17eb0~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=kilC4zy6o%2BxP%2Fu836eLkPMFVDd4%3D" length="0" type="false"/></item><item><title><![CDATA[使用 LangChain 创建一个简单的 Agent]]></title><description><![CDATA[LangChain、AI SDK、Agent、LangSmith这么多名词你知道是什么吗？文章实现了一个的 Agent 可以回答某地区的天气情况，助你搞明白这些东西是什么！]]></description><link>https://blog.vaebe.cn//article/7574633217761460278</link><guid isPermaLink="false">7574633217761460278</guid><pubDate>Thu, 20 Nov 2025 09:02:01 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/d898f411148f41abb014810c4421931d~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=UOfbRKYJJlQ0eFqvRf8pbg2ANus%3D" length="0" type="false"/></item><item><title><![CDATA[测试文章发布]]></title><description><![CDATA[测试文章发布]]></description><link>https://blog.vaebe.cn//article/c3b26cc3e6964633af2745e61f1445f9</link><guid isPermaLink="false">c3b26cc3e6964633af2745e61f1445f9</guid><pubDate>Wed, 17 Sep 2025 02:03:44 GMT</pubDate><enclosure url="https://ik.imagekit.io/rd6uaq2vg/blog/2025-07-04/41098e3bb81b43519672451ba09988d8~tplv-73owjymdk6-jj-mark-v1_0_0_0_0_5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X_q75_dhwXhl-2m.webp?updatedAt=1751591004315" length="0" type="false"/></item><item><title><![CDATA[VMware Mac m系列安装 Windws 11，保姆级教程]]></title><description><![CDATA[本文实践了 VMware Fusion Mac 安装 win11 的过程，通过安装 VMware-tools 解决 win11 安装后没有网络的情况，堪称保姆级教程！]]></description><link>https://blog.vaebe.cn//article/7536900619337859114</link><guid isPermaLink="false">7536900619337859114</guid><pubDate>Mon, 11 Aug 2025 08:45:24 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/8de18af929bd4ed88f273d2e24761d4d~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=%2Br6%2FM7hS81yhAhimM7JJS8MMFdM%3D" length="0" type="false"/></item><item><title><![CDATA[优化 Nextjs 开发的个人博客首页，秒开！]]></title><description><![CDATA[本文实践了将使用 Nextjs 开发个人博客首页由客户端渲染转换为服务端渲染 + 接口数据缓存的方式，让个人博客首页达到了秒开的效果]]></description><link>https://blog.vaebe.cn//article/7513781200416391218</link><guid isPermaLink="false">7513781200416391218</guid><pubDate>Tue, 10 Jun 2025 00:31:29 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/73e5326ef0b74a939258398a6da1d692~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=5q2noazZuXnOzRwjSvG2LB%2BWVkU%3D" length="0" type="false"/></item><item><title><![CDATA[MCP Server 的三种实现]]></title><description><![CDATA[MCP 规范定义了三种标准的传输机制：标准输入和标准输出的通信 STDIO、服务器发送事件 SSE、可流式传输 HTTP 对应三种MCP Server 的实现， SSE 已经是旧的标准预计会被取代！]]></description><link>https://blog.vaebe.cn//article/7505325778222530611</link><guid isPermaLink="false">7505325778222530611</guid><pubDate>Mon, 19 May 2025 01:11:48 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/d174191c2a4f4c8296e4e56ef0841d7e~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=vziNOs%2BahyiaDQg9Btur9Wsw%2FvU%3D" length="0" type="false"/></item><item><title><![CDATA[前端也需要了解的 mcp 知识]]></title><description><![CDATA[本文回答了作者的一些疑问： MCP 是什么、可以干什么？如何实现一个 MCP？如何测试 MCP 服务？如何使用 MCP ？]]></description><link>https://blog.vaebe.cn//article/7495598591488016394</link><guid isPermaLink="false">7495598591488016394</guid><pubDate>Tue, 22 Apr 2025 01:20:46 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/1261e5ceab9b414fb6088375af9b7b14~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=zQLwV6C%2BrzLWZIPmKZ97UsoxSKI%3D" length="0" type="false"/></item><item><title><![CDATA[答应我不要把 mitt 挂载到 vue3 的 globalProperties 上好吗？]]></title><description><![CDATA[直接将 mitt 挂载到 globalProperties 上 非最佳做法。vue 官方建议谨慎使用 globalProperties，而 getCurrentInstance 已只作内部使用。]]></description><link>https://blog.vaebe.cn//article/7484705232904814618</link><guid isPermaLink="false">7484705232904814618</guid><pubDate>Mon, 24 Mar 2025 01:20:56 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/f5616126ac9746d998ab05fd577d7ace~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=25PZRWs%2FriGxyj9SuJ2qUQX357Y%3D" length="0" type="false"/></item><item><title><![CDATA[这位同学说一说 vue3 的 Provide、Inject]]></title><description><![CDATA[本文介绍了vue3 的 Provide、Inject 的使用及一些使用中的细节，而后通过阅读源码来理解 Provide、Inject 是如何实现的。]]></description><link>https://blog.vaebe.cn//article/7480514589253468169</link><guid isPermaLink="false">7480514589253468169</guid><pubDate>Wed, 12 Mar 2025 05:50:33 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/09fba5d80ab642d3bb8ec692c679d406~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240635&amp;x-signature=P7Eo4I6XtcpWjJkc59sfyeYy83o%3D" length="0" type="false"/></item><item><title><![CDATA[这位同学来说一说 vue3 的组件通信]]></title><description><![CDATA[Vue 组件间通信的多种方案：父传子通过 Props 和回调函数，子传父使用 emit；跨组件通信涵盖 Provide/Inject、共享状态模式及事件总线。]]></description><link>https://blog.vaebe.cn//article/7480081951517900800</link><guid isPermaLink="false">7480081951517900800</guid><pubDate>Tue, 11 Mar 2025 00:46:03 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/2e07b41d14d144a8b90fa231abc70c52~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=n814ZMzY4UUkEW%2Fe4nBtQnK19cE%3D" length="0" type="false"/></item><item><title><![CDATA[解决浏览器麦克风持续显示使用中的问题]]></title><description><![CDATA[开发过程中遇到一个奇怪的问题：当用户进入某语音评测功能页面时，浏览器地址栏的麦克风图标一直显示为“正在使用中”，切换到其他页面也未能清除这一状态。 用户因此误会我们在后台偷偷录音。]]></description><link>https://blog.vaebe.cn//article/7476977628777431092</link><guid isPermaLink="false">7476977628777431092</guid><pubDate>Mon, 03 Mar 2025 03:33:25 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/3452ba84d63d48f88e9614dbdb0e68e0~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=H6w7dgt94bx8%2F7GBrmBPsf0w%2FjI%3D" length="0" type="false"/></item><item><title><![CDATA[深入解析 mitt 和 vueuse useEventBus 的实现]]></title><description><![CDATA[`mitt` 和 `vueuse useEventBus` 都是对事件的发布订阅的实现，只用大约 40 行代码就实现了完整的功能]]></description><link>https://blog.vaebe.cn//article/7457228085830778895</link><guid isPermaLink="false">7457228085830778895</guid><pubDate>Wed, 08 Jan 2025 00:59:07 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/5d49d79583f54e85ba23cda5713e245e~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=Aj2xVDGTANxMu0sTgM4bbQN9Ahg%3D" length="0" type="false"/></item><item><title><![CDATA[vite 插件打包时记录项目的版本信息让外部访问]]></title><description><![CDATA[前端项目不依赖后端如何向外部提供可访问的版本信息呢？本文通过实现一个 vite 插件在打包时生成项目的版本信息然后让外部可以通过请求来获取。]]></description><link>https://blog.vaebe.cn//article/7456809080344133667</link><guid isPermaLink="false">7456809080344133667</guid><pubDate>Tue, 07 Jan 2025 01:07:02 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/0089e8d2a62c46feab74a1b6ea7b8481~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=rSyqziqIAUfyZuSOd81o2kLwBpY%3D" length="0" type="false"/></item><item><title><![CDATA[mswjs 让前端 mock 不只是在本地]]></title><description><![CDATA[MSW.js 是一款强大的前端接口模拟库，不仅支持本地开发，还能部署线上使用。通过拦截网络请求，灵活返回 REST、GraphQL 和 WebSocket 的模拟数据，是调试和测试的理想工具。]]></description><link>https://blog.vaebe.cn//article/7445926398400102440</link><guid isPermaLink="false">7445926398400102440</guid><pubDate>Mon, 09 Dec 2024 01:23:13 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/df9fa4b4aa8c45b381ca660d30c2f842~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=IEFf%2FQ2PjQO09rHPfBbc8dc59Ak%3D" length="0" type="false"/></item><item><title><![CDATA[vueuse 源码: createEventHook]]></title><description><![CDATA[本文分析了 vueuse 中 createEventHook 函数的作用以及实现！虽然只有不到 30 行代码但实现思路仍值得我们学习！]]></description><link>https://blog.vaebe.cn//article/7439367850488070159</link><guid isPermaLink="false">7439367850488070159</guid><pubDate>Thu, 21 Nov 2024 00:44:51 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/fd0c6a965c0c4153ab7139f997f94edb~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=mGZqL7y5fCeQRtwRMM%2B5gI9wYlE%3D" length="0" type="false"/></item><item><title><![CDATA[nextjs 使用 imagekit api 完成文件上传]]></title><description><![CDATA[本文使用 nextjs、imagekit api 实现了项目的文件上传, imageKit 是一款包含图像优化、处理和存储解决方案,免费计划提供 5GB 的存储空间]]></description><link>https://blog.vaebe.cn//article/7438640311457087522</link><guid isPermaLink="false">7438640311457087522</guid><pubDate>Tue, 19 Nov 2024 00:27:04 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/661f162e623a4d5eaa0581f73a441aca~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=TNusKxI8vebeIU37GnRWI8x4LCY%3D" length="0" type="false"/></item><item><title><![CDATA[create-vite 源码阅读]]></title><description><![CDATA[本文分析了 `create-vite` 的源码**核心逻辑是根据用户的选择将现有的模版复制到对应的目录** init 函数中实现了这一逻辑]]></description><link>https://blog.vaebe.cn//article/7433608225398620175</link><guid isPermaLink="false">7433608225398620175</guid><pubDate>Tue, 05 Nov 2024 05:41:57 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/41666a8ed8f94218ae5018d8b9098c4b~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=QVk5TXD8s9ZR62deDxbdrvQ0nBk%3D" length="0" type="false"/></item><item><title><![CDATA[使用 nextjs 构建 ai 对话页面]]></title><description><![CDATA[本文实践了如何用 Next.js 、智谱 AI 的 GLM-4-Flash 模型（免费）、 Vercel AI SDK 搭建一个简单的对话式 AI 页面]]></description><link>https://blog.vaebe.cn//article/7431580770214543375</link><guid isPermaLink="false">7431580770214543375</guid><pubDate>Thu, 31 Oct 2024 01:40:10 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/8047d9559cc74906a0605174c0b729b2~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=pDs51Pppw4SZdBmmOklO9RcSFQA%3D" length="0" type="false"/></item><item><title><![CDATA[Next.js 定时同步掘金文章到个人博客]]></title><description><![CDATA[通过 Next.js 和 Prisma，自动将掘金的文章同步到博客数据库。结合 MySQL 和 API 接口，定时抓取和存储掘金最新文章数据并在个人博客中展示]]></description><link>https://blog.vaebe.cn//article/7431226853250564096</link><guid isPermaLink="false">7431226853250564096</guid><pubDate>Wed, 30 Oct 2024 01:56:01 GMT</pubDate><enclosure url="https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/bba3052c8b2349c5b4af94b95b79de57~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240642&amp;x-signature=D3SdLYPWwREPOImwBABuuBTsYCE%3D" length="0" type="false"/></item><item><title><![CDATA[写 vue 的我却用 nextjs 开发个人博客]]></title><description><![CDATA[使用 Next.js 构建个人博客。实现了多种登录方式、文章管理、掘金内容同步、留言和 AI 对话等功能。]]></description><link>https://blog.vaebe.cn//article/7430494779698806784</link><guid isPermaLink="false">7430494779698806784</guid><pubDate>Mon, 28 Oct 2024 00:22:46 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/41098e3bb81b43519672451ba09988d8~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=Jfa%2FSweKZvU7jcNXPp%2FexDTAWbo%3D" length="0" type="false"/></item><item><title><![CDATA[nextjs集成掘金 bytemd 编辑器]]></title><description><![CDATA[本文实践了在 nextjs 中如何集成掘金的 bytemd 编辑器以及插件的集成 封装了一个编辑器组件和预览组件 因为官方没有提供深色主题所以还自行实现了深色主题的样式]]></description><link>https://blog.vaebe.cn//article/7423980772172087331</link><guid isPermaLink="false">7423980772172087331</guid><pubDate>Fri, 11 Oct 2024 00:30:27 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/783e8d95e86c46a3826ce161f11e3cce~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=Z9qbEpYPyPtARtyEohv0Oc5jwF8%3D" length="0" type="false"/></item><item><title><![CDATA[Vue3组件二次封装的小技巧]]></title><description><![CDATA[本文实践了Vue3组件二次封装的三个实用技巧:实现双向数据绑定、向子组件传递插槽、获取子组件ref。通过实际代码示例,展示了使用defineModel、h函数和Proxy等新特性来简化和优化组件封装过]]></description><link>https://blog.vaebe.cn//article/7413194176006324275</link><guid isPermaLink="false">7413194176006324275</guid><pubDate>Thu, 12 Sep 2024 00:12:34 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/43ba431d8ad242adabe5a1cb5acc7c9d~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=8ubOhjCA7K7%2F31yZ1CRU4w%2FvOOE%3D" length="0" type="false"/></item><item><title><![CDATA[NestJS 使用 TypeORM CLI 高效管理数据库变更]]></title><description><![CDATA[在 NestJS 项目中，利用 TypeORM CLI 管理数据库变更能够高效地将本地表字段的修改应用到生产数据库。这种方法显著减少了手动操作可能导致的遗漏和错误，确保数据库结构的一致性与可靠性。]]></description><link>https://blog.vaebe.cn//article/7402444509153591308</link><guid isPermaLink="false">7402444509153591308</guid><pubDate>Wed, 14 Aug 2024 00:23:01 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/4af0d3c574644fe0b49afc70d7b49260~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=RwVzOy3h44YK8P5lCqM7%2BYai79U%3D" length="0" type="false"/></item><item><title><![CDATA[网站集成 github 登录太简单了!]]></title><description><![CDATA[本文实践了 web 网站如何集成 github 登录,前后端代码均已开源 前端需要调用一个接口,后端需要调用两个接口即可完成]]></description><link>https://blog.vaebe.cn//article/7393551590458998819</link><guid isPermaLink="false">7393551590458998819</guid><pubDate>Mon, 22 Jul 2024 01:17:58 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/1d2ba27b52ab46e8a88c836a55175455~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=aOtgDQHShQ0rLT4VKqGmrjMgHDc%3D" length="0" type="false"/></item><item><title><![CDATA[写一个双 token demo 含前后端实现]]></title><description><![CDATA[本文通过一张图介绍了双 token 的执行流程以及双 token 有什么好处,然后对双 token 机制进行了实践包含前端后端实现]]></description><link>https://blog.vaebe.cn//article/7392070976093995071</link><guid isPermaLink="false">7392070976093995071</guid><pubDate>Tue, 16 Jul 2024 14:50:50 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/dbc89337b1ad415d81aeac166382477d~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=9zwKdsa3g7RpnS%2FbWVf1J1ZAu1Y%3D" length="0" type="false"/></item><item><title><![CDATA[GitHub actions 自动部署 goframe 项目到云服务器]]></title><description><![CDATA[一个 goframe 项目部署居然会让我来来回回折腾三次 第一次: goframe 手动打包部署 第二次: GitHub actions + docker 自动部署 第三次:😳]]></description><link>https://blog.vaebe.cn//article/7391704618180526080</link><guid isPermaLink="false">7391704618180526080</guid><pubDate>Mon, 15 Jul 2024 05:26:30 GMT</pubDate><enclosure url="https://p6-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/68059a582e104018a1d5f88f6812fb03~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=TnwSeA4ik5GGQUdJ1DB56LC8Q0I%3D" length="0" type="false"/></item><item><title><![CDATA[nuxt3配置pwa]]></title><description><![CDATA[本文实践了在 nuxt3 中如何配置 pwa,当然是比较简单的实践 pwa 作为渐进式 Web 应用能做不止如此!]]></description><link>https://blog.vaebe.cn//article/7386848746914480168</link><guid isPermaLink="false">7386848746914480168</guid><pubDate>Wed, 03 Jul 2024 01:25:02 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/2990de141ff5433dac22f993b42c92da~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[20分钟,实现一个根据ip查询地理信息的接口]]></title><description><![CDATA[20分钟带你实现根据ip查询地理信息的服务接口,地理信息数据的获取、vercel functions 无服务器函数的使用]]></description><link>https://blog.vaebe.cn//article/7375438737234247719</link><guid isPermaLink="false">7375438737234247719</guid><pubDate>Mon, 03 Jun 2024 00:32:47 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/5d1dbf2ab3a44f3a8a475af3e6f20afb~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[GitHub actions + docker 自动部署 goframe 项目]]></title><description><![CDATA[首先来说需要实现一种什么效果 当我们写完代码打上 git tag 推送到 GitHub 仓库时自动触发 GitHub actions 工作流,将项目打包并自动发布更新]]></description><link>https://blog.vaebe.cn//article/7352555529104425012</link><guid isPermaLink="false">7352555529104425012</guid><pubDate>Mon, 01 Apr 2024 00:02:45 GMT</pubDate><enclosure url="https://p26-juejin-sign.byteimg.com/tos-cn-i-k3u1fbpfcp/b69426858a694be78e563e4d16efbe59~tplv-k3u1fbpfcp-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240649&amp;x-signature=0FR88n3jxk2ePYsja2HFw4UgjH0%3D" length="0" type="false"/></item><item><title><![CDATA[五年前端这题都做不对?]]></title><description><![CDATA[实现汗颜,作为一个多年的老前端做了一遍题居然不及格! 一时陷入了反思中备受打击,诚请各位大哥来一探究竟!]]></description><link>https://blog.vaebe.cn//article/7349750846899699764</link><guid isPermaLink="false">7349750846899699764</guid><pubDate>Sun, 24 Mar 2024 23:55:18 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/e7af3ec3f7324cf893eb0c93835009be~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[goframe 手动打包部署]]></title><description><![CDATA[本文介绍了 goframe 项目本地打包后如何部署云服务器,以及接口 https 的配置申请证书到 nginx 配置]]></description><link>https://blog.vaebe.cn//article/7348474490757054504</link><guid isPermaLink="false">7348474490757054504</guid><pubDate>Thu, 21 Mar 2024 08:58:24 GMT</pubDate><enclosure url="https://p9-juejin-sign.byteimg.com/tos-cn-i-k3u1fbpfcp/bf72b5dfdf254fcabc01e349fa396571~tplv-k3u1fbpfcp-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240655&amp;x-signature=vFsIhXZQMmqOup9PkSJ8iE9AHvk%3D" length="0" type="false"/></item><item><title><![CDATA[go 基础2]]></title><description><![CDATA[这里是 go 基础大部分内容来源于一门视频课程 ,学完后再来看手摸手开发一个全栈项目就基本可以直接上手了,项目本身没有什么难度!]]></description><link>https://blog.vaebe.cn//article/7345792819754025012</link><guid isPermaLink="false">7345792819754025012</guid><pubDate>Thu, 14 Mar 2024 02:35:17 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/04e183d9b9804c6084b6c209905d3f71~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[go 基础语法]]></title><description><![CDATA[这里是 go 的基本语法大部分内容来源于一门视频课程 学完后再来看手摸手开发一个全栈项目就基本可以直接上手了,项目本身没有什么难度!]]></description><link>https://blog.vaebe.cn//article/7345758899305414708</link><guid isPermaLink="false">7345758899305414708</guid><pubDate>Wed, 13 Mar 2024 13:43:00 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/b79ba8493a3d4399b15052b0e9ef4885~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[手摸手开发一个全栈项目]]></title><description><![CDATA[手摸手开发一个短链生成管理平台,前端: vite5、vue3全家桶、element-plus、vueuse,后端: goframe、go(1.18)、mysql、redis、七牛云 oss、邮件发送]]></description><link>https://blog.vaebe.cn//article/7345310754470887458</link><guid isPermaLink="false">7345310754470887458</guid><pubDate>Tue, 12 Mar 2024 09:45:21 GMT</pubDate><enclosure url="https://p9-juejin-sign.byteimg.com/tos-cn-i-k3u1fbpfcp/5011a25fb0d043b7b580c16c0cbd1eb6~tplv-k3u1fbpfcp-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240655&amp;x-signature=YhjtmESHV4Csj3suL2tTY4hc%2FSU%3D" length="0" type="false"/></item><item><title><![CDATA[使用turfjs、地图实现附近充电宝]]></title><description><![CDATA[是的，我看过大佬写的Nest + Redis + 地图，实现附近的充电宝这给我提供了写作的灵感，感谢大佬！ 既然通过后端支持可以实现附近点位检索的功能，那么依靠纯前端可以实现吗？ 答案是可以的]]></description><link>https://blog.vaebe.cn//article/7295644677742985226</link><guid isPermaLink="false">7295644677742985226</guid><pubDate>Tue, 31 Oct 2023 00:30:52 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/570c5b333fea4e8988b769e50010e392~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1000&amp;h=550&amp;s=163611&amp;e=jpg&amp;b=f1efe7" length="0" type="false"/></item><item><title><![CDATA[go ➕ “蓝兔支付”实现个人网上支付]]></title><description><![CDATA[支付宝、微信的网上支付需要营业执照个人无法直接使用。 如果个人需要实现网上支付功能，目前大部分应该是都是依赖第三方聚合支付来实现。本文使用蓝兔支付来实现个人网上支付功能。]]></description><link>https://blog.vaebe.cn//article/7280007090768298040</link><guid isPermaLink="false">7280007090768298040</guid><pubDate>Mon, 18 Sep 2023 12:20:57 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/07dde4609bbe403dad215fd3f15ab877~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[看了官网让我对自己关于ref、reactive的理解产生了怀疑！]]></title><description><![CDATA[vue3 中 ref 与 reactive 有各自的适用场景，单纯的使用 ref 一把梭与定义一个 reactive 把所有变量都塞进去都不是一个推荐的做法。]]></description><link>https://blog.vaebe.cn//article/7279598329023971384</link><guid isPermaLink="false">7279598329023971384</guid><pubDate>Mon, 18 Sep 2023 01:10:44 GMT</pubDate><enclosure url="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/65402b686d804f029923b326a941772f~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[生成指定辖区内随机点]]></title><description><![CDATA[在 web 地图开发过程中可能需要根据某一个区域生成一些随机点用来做测试。 之前在某个网站有这个功能是借助百度地图相关 api 来实现的，那我们不借助这些地图厂商的 api 可以实现吗？答案是可以的]]></description><link>https://blog.vaebe.cn//article/7271974618565591097</link><guid isPermaLink="false">7271974618565591097</guid><pubDate>Sun, 27 Aug 2023 23:58:12 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/ec630d6aafaf4705953d23fa78c8d507~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[一个开源的leafletjs示例项目]]></title><description><![CDATA[一个 vue3.x 与 leafletjs 结合使用示例的开源项目，让新手 leafletjs 使用更加简单，欢迎大家共建。]]></description><link>https://blog.vaebe.cn//article/7269411820905087013</link><guid isPermaLink="false">7269411820905087013</guid><pubDate>Mon, 21 Aug 2023 03:33:26 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/e6198d1564a344a58bf0b4aba02b8f71~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[Pinia极速通关！]]></title><description><![CDATA[Pinia 是一个状态管理库与 vuex 的作用及定位一致。 同时支持 vue2、3（会有部分差异）最重要的一点是它支持 组合式API，也因为此它会比 vuex 更加灵活。]]></description><link>https://blog.vaebe.cn//article/7267441882397016103</link><guid isPermaLink="false">7267441882397016103</guid><pubDate>Tue, 15 Aug 2023 13:52:54 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/359577c398fb4d70b266f9ecc011ce28~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[nuxt3 多环境配置及部署]]></title><description><![CDATA[文章主要介绍了 nuxt3 中多环境的打包及部署，在 nuxt3 中使用不同的 env 文件可以实现不同环境的打包。文章最后还介绍了使用Nginx 部署打包后的文件及配置 https 访问。]]></description><link>https://blog.vaebe.cn//article/7267437885858463756</link><guid isPermaLink="false">7267437885858463756</guid><pubDate>Tue, 15 Aug 2023 13:25:53 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/aec56531c40e426fa3ff57b263ba51ca~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[改了个element-plus文档的错误]]></title><description><![CDATA[改了个 tree 组件 setCheckedKeys 方法的描述 这个文档错误比较老🤔最开始就是错的(看记录是一直都没有修复过的)！ 现在 element-ui 的文档依然是错误的！]]></description><link>https://blog.vaebe.cn//article/7233053557833695293</link><guid isPermaLink="false">7233053557833695293</guid><pubDate>Sun, 14 May 2023 23:43:50 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/4c6312de49854aaea7e401befe7843b9~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[七牛云使用自定义域名]]></title><description><![CDATA[记录配置七牛云自定义域名的过程，访问内容需要https支持的话需要申请证书，不需要https则不需要。]]></description><link>https://blog.vaebe.cn//article/7219968440761942077</link><guid isPermaLink="false">7219968440761942077</guid><pubDate>Sun, 09 Apr 2023 12:56:03 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/dcf32dda74ce46c995945dd26d648962~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[你有没有好奇过vue文档的检索是怎么实现的？]]></title><description><![CDATA[本文详细实践了如何为文档增加 `algolia` 检索，实现类似vue文档的检索效果，最终也是为vue devui 的文档增加了文档检索功能。]]></description><link>https://blog.vaebe.cn//article/7178640669999628349</link><guid isPermaLink="false">7178640669999628349</guid><pubDate>Sun, 18 Dec 2022 23:58:01 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/77806506af764c1d973063f8a5e56458~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[localStorage容量太小?试试它们]]></title><description><![CDATA[localStorage 的存储大小在 5M - 10M，在一些场景下 根本不够用，可使用 IndexedDB 存储数据其大小一般在 `250M` 以上]]></description><link>https://blog.vaebe.cn//article/7163075131261059086</link><guid isPermaLink="false">7163075131261059086</guid><pubDate>Mon, 07 Nov 2022 01:10:17 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/c4bc74cc526c4d07a92ef18e708c3988~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[我相信这是vue3复用代码的正确姿势！]]></title><description><![CDATA[在vue2中代码复用一般是 mixins 混入来实现但使用 mixins 进行代码复用会有一些问题 vue3虽然对 mixins 进行了保留但不再推荐使用。]]></description><link>https://blog.vaebe.cn//article/7160480314089799710</link><guid isPermaLink="false">7160480314089799710</guid><pubDate>Mon, 31 Oct 2022 01:21:17 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/5cade6e598d5490ea33546d6168eb729~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[垃圾代码的一些特点！]]></title><description><![CDATA[是什么样的代码让同事直呼“卧槽”、让技术经理羞愤难当、让老板黯然落泪！！！同事看了已经三天没理我了！]]></description><link>https://blog.vaebe.cn//article/7129305693978361886</link><guid isPermaLink="false">7129305693978361886</guid><pubDate>Mon, 08 Aug 2022 01:07:35 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/397acd881794437abc0701db41f48ca9~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[从零到一建立属于自己的前端组件库]]></title><description><![CDATA[超越站内九成建设组件库的文章，真正从零到一实现企业级前端组建库建设，历时一周总结完善，项目技术栈 vite3、vitepress、vitest、vue3、tsx]]></description><link>https://blog.vaebe.cn//article/7124487017588588574</link><guid isPermaLink="false">7124487017588588574</guid><pubDate>Tue, 26 Jul 2022 01:29:00 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/ccbee14aabf84679b75a0db5ded709ae~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[vue3-ccui之组件库打包发布]]></title><description><![CDATA[超越站内九成建设组件库的文章，真正从零到一实现企业级前端组建库建设，历时一周总结完善，项目技术栈 vite3、vitepress、vitest、vue3、tsx]]></description><link>https://blog.vaebe.cn//article/7124486974211096612</link><guid isPermaLink="false">7124486974211096612</guid><pubDate>Tue, 26 Jul 2022 01:28:12 GMT</pubDate><enclosure url="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/c029f6fa9fe04c86bdf1b6ed8e980511~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[夏天需要吃西瓜,项目也需要Lint工具链！]]></title><description><![CDATA[本文将从零到一介绍 Eslint、Prettier、Stylelint、Commitlint、ls-lint 的安装配置以及结合 Husky+lint-staged 做自动化检查]]></description><link>https://blog.vaebe.cn//article/7123516611528654884</link><guid isPermaLink="false">7123516611528654884</guid><pubDate>Sat, 23 Jul 2022 10:43:23 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/c5e91a0aa7d1404d9b50fab944de316f~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[不要用vue2的思维写vue3]]></title><description><![CDATA[不要用vue2.x的思维去写vue3.x，两者虽是同源，但是sfc与setup的代码组织方式有一定的差别。]]></description><link>https://blog.vaebe.cn//article/7105930378052894750</link><guid isPermaLink="false">7105930378052894750</guid><pubDate>Mon, 06 Jun 2022 01:19:19 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/0ef602e2d7794ab5b601b1ff11b46cd9~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[el-Cascader懒加载数据回显]]></title><description><![CDATA[踩坑实践，这是正确的 el-Cascader懒加载数据回显 处理方式，问题很简单，但是处理不好也是要浪费一些时间的]]></description><link>https://blog.vaebe.cn//article/7103106647714693150</link><guid isPermaLink="false">7103106647714693150</guid><pubDate>Sun, 29 May 2022 10:42:29 GMT</pubDate></item><item><title><![CDATA[获取省、市、区、乡镇边界数据geojson]]></title><description><![CDATA[这是正确的！！！！亲测可用的 获取乡镇边界的方法。 两种方式 一种直接拿转换好的geojson数据，一种自己转换。 一， 阿里云盘 全国乡镇边界数据 「我国乡镇行政区划.json」，点击链接保存，或者]]></description><link>https://blog.vaebe.cn//article/7095541155554656287</link><guid isPermaLink="false">7095541155554656287</guid><pubDate>Mon, 09 May 2022 01:25:21 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/9b5d029c2e844e608e18a356fc8f738a~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[git将某个分支的n次提交合并到任意分支]]></title><description><![CDATA[将任意分支的任意提交合并到任意的分支。 git cherry-pick git rebase 结合实现。]]></description><link>https://blog.vaebe.cn//article/7094936981309751309</link><guid isPermaLink="false">7094936981309751309</guid><pubDate>Sat, 07 May 2022 10:20:11 GMT</pubDate><enclosure url="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cee7899074fc4730a8158e3941244d36~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[求求你们了，对自己代码质量有点要求！]]></title><description><![CDATA[最近在合并几个项目的代码，把功能拼一拼简称项目拼多多。 几个系统都没有 eslint 之类的东西，我居然想给 拼多多 加上代码检查。我还真的干了，于是就有了下面这些奇奇怪怪甚至有甚至有些可爱的代码。]]></description><link>https://blog.vaebe.cn//article/7073049322656366622</link><guid isPermaLink="false">7073049322656366622</guid><pubDate>Wed, 09 Mar 2022 10:47:47 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/2d214acf20da41bfb01d9ef599fff52c~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[vue多页实践-nginx部署]]></title><description><![CDATA[nginx 部署多页应用实践，多页打包多应用部署，多页打包单应用部署，遇到一些坑比如 部分应用无法访问静态资源。]]></description><link>https://blog.vaebe.cn//article/7054364212243464229</link><guid isPermaLink="false">7054364212243464229</guid><pubDate>Tue, 18 Jan 2022 02:16:10 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/0c7d8ccf28724b2fb44772d6bb98ad71~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[vue多页实践-开发]]></title><description><![CDATA[从零到一将vue-cli创建的spa应用改造为多页应用，内含多应用打包，单应用打包配置（.env环境区分）。]]></description><link>https://blog.vaebe.cn//article/7053979399716077576</link><guid isPermaLink="false">7053979399716077576</guid><pubDate>Mon, 17 Jan 2022 01:23:32 GMT</pubDate><enclosure url="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/28367412c66f4448b14d1ac15659fa17~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[vue3+elementPlus主题动态切换2022，亲测可用！]]></title><description><![CDATA[本文实践了vue3.x +elementPlus-ui实现动态主题切换，可能是目前最完整的换肤方案，亲测可用！！！！]]></description><link>https://blog.vaebe.cn//article/7035793403342225445</link><guid isPermaLink="false">7035793403342225445</guid><pubDate>Mon, 29 Nov 2021 01:13:00 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/ea2f97a7c9c5479ab84588bb87ede6ed~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[自定义高德地图深色主题]]></title><description><![CDATA[有一说一，高德地图的深色主题，是真的欣赏不来。让我们来自定义一个深色主题。 高德地图官方提供了在线主题生成工具。]]></description><link>https://blog.vaebe.cn//article/7030714373878480910</link><guid isPermaLink="false">7030714373878480910</guid><pubDate>Mon, 15 Nov 2021 08:43:16 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f1d6478fc0fe4344a38b6192d1bf71da~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[vue + element-ui动态主题及网站换肤2021，亲测可用！！！]]></title><description><![CDATA[本文使用vue+element-ui实现了 element-ui动态主题更换（基本无需额外书写css 覆盖样式）及网站动态换肤。]]></description><link>https://blog.vaebe.cn//article/7028395505075879967</link><guid isPermaLink="false">7028395505075879967</guid><pubDate>Tue, 09 Nov 2021 02:44:15 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f16d66e2403849ad9d726a3e0853c161~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[element-ui定制主题]]></title><description><![CDATA[element-ui 定制属于自己主题，不需要覆盖原有element-ui原有样式即可实现深色主题。]]></description><link>https://blog.vaebe.cn//article/7028109582941552676</link><guid isPermaLink="false">7028109582941552676</guid><pubDate>Mon, 08 Nov 2021 08:15:42 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/5734c4b257ed4a119562cc3b724f6272~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[使用patch-package修改`node_modules`]]></title><description><![CDATA[通过使用patch-package修改`node_modules`，以解决因为三方依赖中存在特定信息导致的信息漏洞！]]></description><link>https://blog.vaebe.cn//article/7026890736649895944</link><guid isPermaLink="false">7026890736649895944</guid><pubDate>Fri, 05 Nov 2021 01:26:21 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cea20ae06a124f7ba950e04eb46f7e00~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=1303&amp;h=734&amp;s=479373&amp;e=jpg&amp;b=a90000" length="0" type="false"/></item><item><title><![CDATA[我是真的记不全ES6+所有知识啊！]]></title><description><![CDATA[es6-11学习总结，是在是太多了，我是真的记不住啊！ 本文很多参考 mdn，因为它相对权威 且含有非常多的示例。]]></description><link>https://blog.vaebe.cn//article/7017738155725946910</link><guid isPermaLink="false">7017738155725946910</guid><pubDate>Mon, 11 Oct 2021 09:29:10 GMT</pubDate><enclosure url="https://p3-juejin-sign.byteimg.com/tos-cn-i-k3u1fbpfcp/7f5d25d70f234157b749e03b1aeca831~tplv-k3u1fbpfcp-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240675&amp;x-signature=L5Q1FWEhPIoeNaDd7hOXYC42qmw%3D" length="0" type="false"/></item><item><title><![CDATA[openlayers 实战离线地图]]></title><description><![CDATA[从零到一 带你实战 openlayers 离线地图的使用，内容包括： 获取离线地图瓦片 openlayers加载离线地图瓦片 显示地理坐标 显示地理坐标范围。]]></description><link>https://blog.vaebe.cn//article/7017301189406490655</link><guid isPermaLink="false">7017301189406490655</guid><pubDate>Sun, 10 Oct 2021 05:22:54 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/4ba1fab0381b4afd95ce9e96e672cb78~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[这两个前端下载库推荐给你]]></title><description><![CDATA[简介 本文介绍两个下载库的使用 1. js-file-download 2. FileSaver.js 两者各有优劣。 使用库的意义在于，库的作者已经处理了很多问题比如兼容。而越多人使用的库也越有保证]]></description><link>https://blog.vaebe.cn//article/7004004799725174798</link><guid isPermaLink="false">7004004799725174798</guid><pubDate>Sat, 04 Sep 2021 09:16:47 GMT</pubDate><enclosure url="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/26c500f82ed4420d9a412ce2ca0e8f13~tplv-k3u1fbpfcp-watermark.image" length="0" type="false"/></item><item><title><![CDATA[高德地图雷达扫描效果实现]]></title><description><![CDATA[一看就会，十分钟看完。后边用到不挠头发。 这个其实没什么难点，在地图上动效不是很常见，最主要的是我在搜索高德地图雷达扫描, 地图雷达扫描 得到的并没有直接能用的。某篇文章的评论下一位老哥评论说 我是很]]></description><link>https://blog.vaebe.cn//article/6999177373853679646</link><guid isPermaLink="false">6999177373853679646</guid><pubDate>Sun, 22 Aug 2021 09:07:20 GMT</pubDate><enclosure url="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/2b17d3777722422b97792fd7b1d7e1d3~tplv-k3u1fbpfcp-watermark.image" length="0" type="false"/></item><item><title><![CDATA[手摸手之日历组件]]></title><description><![CDATA[开始 本文纯靠自己思路来写，如有雷同，也不是抄袭。 阅读本文前，需要了解一点ts，vue3，jsx语法。😯 还有moment相关语法。 预想效果 or 实际效果 简直是一模一样😄 预想效果 eleme]]></description><link>https://blog.vaebe.cn//article/6996264079648096264</link><guid isPermaLink="false">6996264079648096264</guid><pubDate>Sat, 14 Aug 2021 12:38:12 GMT</pubDate><enclosure url="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/35ddc9d813be41e0b0352eb149d20719~tplv-k3u1fbpfcp-watermark.image" length="0" type="false"/></item><item><title><![CDATA[手摸手之JSX card卡片组件]]></title><description><![CDATA[card 卡片 相对其他一些组件比较简单，但是也有一些内在天地。 前置知识 vue3 vue-jsx vue组件插槽 上边不懂也没关系 能看的懂 或者看一些这个 vue3 JSX 从零开始 开始 新建]]></description><link>https://blog.vaebe.cn//article/6977294016517767205</link><guid isPermaLink="false">6977294016517767205</guid><pubDate>Thu, 24 Jun 2021 09:45:06 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/bf509ea6c1964d4582972df61da4f692~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[vue3 JSX 从零开始]]></title><description><![CDATA[本文讲解了vue中的jsx 基本语法及详细使用案例。新手友好。适合新手观看。需要了解vue相关知识。友情提示请阅读官方文档。]]></description><link>https://blog.vaebe.cn//article/6969079432371765262</link><guid isPermaLink="false">6969079432371765262</guid><pubDate>Wed, 02 Jun 2021 06:29:42 GMT</pubDate></item><item><title><![CDATA[webRtc 流媒体播放-vue]]></title><description><![CDATA[1. JSWebrtc 对浏览器的 Webrtc 做了简单的封装，支持 SRS 的 RTC 流的播放. 2. 描述了如何让在vue中使用JSWebrtc 并封装方便调用。]]></description><link>https://blog.vaebe.cn//article/6964320158806458405</link><guid isPermaLink="false">6964320158806458405</guid><pubDate>Thu, 20 May 2021 10:41:52 GMT</pubDate></item><item><title><![CDATA[beego安装]]></title><description><![CDATA[安装beego文档地址安装 bee 工具bee 工具是一个为了协助快速开发 beego 项目而创建的项目，通过 bee 您可以很容易的进行 beego 项目的创建、热编译、开发、测试、和部署。bee ]]></description><link>https://blog.vaebe.cn//article/6950598737890639909</link><guid isPermaLink="false">6950598737890639909</guid><pubDate>Tue, 13 Apr 2021 11:13:04 GMT</pubDate></item><item><title><![CDATA[vue3.0实战踩坑]]></title><description><![CDATA[年前公司开了一个新项目，普通的业务系统，心痒难耐的就上了 3.0 的船，遗憾的是工期比较紧没上ts (我倒是希望搞一搞tsx， 此处叹气),小坑有一点。不过也算是踩过来了。 本文主要整理记录一些，实际开发中遇到的问题，所以vue3.0 实践大佬 可以不用继续看了，面向的是像我一…]]></description><link>https://blog.vaebe.cn//article/6941749743970320421</link><guid isPermaLink="false">6941749743970320421</guid><pubDate>Sat, 20 Mar 2021 14:56:02 GMT</pubDate></item><item><title><![CDATA[手摸手之vue单选组件]]></title><description><![CDATA[本次是一个单选组件，现在基本上可以说是个ui框架都有单选组件。换句话说，你连一个单选组件都没有好意思说自己是个ui框架（开玩笑） 在vue的文档中有一章叫做 表单输入绑定 其中有一章是介绍单选按钮的。]]></description><link>https://blog.vaebe.cn//article/6916299149008699406</link><guid isPermaLink="false">6916299149008699406</guid><pubDate>Mon, 11 Jan 2021 00:53:27 GMT</pubDate></item><item><title><![CDATA[手摸手，配置项目中全局loading]]></title><description><![CDATA[在后台管理项目中接口的请求响应速度取决于很多因素，如网络、带宽、同时发起的请求数量===，无法将请求结果及时响应的页面上，而我们又需要告诉用户，数据已经在加载了，你需要先等一等，喝杯茶。这个时候就需要 loading了 ，但是一个项目里又不仅仅是只有一个请求，每个都写一遍 lo…]]></description><link>https://blog.vaebe.cn//article/6911102469535694856</link><guid isPermaLink="false">6911102469535694856</guid><pubDate>Mon, 28 Dec 2020 00:48:30 GMT</pubDate></item><item><title><![CDATA[ echarts 自动滚动+ tooltip定时移动]]></title><description><![CDATA[其实官网有写，侧面说明了 看文档的重要性。 官网文档中提供的方法依然是通过定时器来修改dispatchAction来实现。]]></description><link>https://blog.vaebe.cn//article/6904096212963000328</link><guid isPermaLink="false">6904096212963000328</guid><pubDate>Wed, 09 Dec 2020 03:40:11 GMT</pubDate></item><item><title><![CDATA[vue中使用地图进行点、线、面绘制（vue + MineMap ）]]></title><description><![CDATA[其实前端使用地图真的没有那么难，任何事物都是讲究方法的，前端使用地图也是一样的。 维基百科这样介绍：GeoJSON是一种基于JSON的地理空间数据交换格式，它定义了几种类型JSON对象以及它们组合在一起的方法，以表示有关地理要素、属性和它们的空间范围的数据。 地球坐标系——WG…]]></description><link>https://blog.vaebe.cn//article/6892673283934666765</link><guid isPermaLink="false">6892673283934666765</guid><pubDate>Sun, 08 Nov 2020 08:53:40 GMT</pubDate><enclosure url="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/49ff416d439f42389dcfa68693fce94d~tplv-k3u1fbpfcp-watermark.image" length="0" type="false"/></item><item><title><![CDATA[不知名的地图？]]></title><description><![CDATA[大概很多人都以为国内地图只有高德、百度、腾讯,其实不然，本文章仅是介绍一些国内地图的大概内容。了解下其他的地图。]]></description><link>https://blog.vaebe.cn//article/6889320541523148807</link><guid isPermaLink="false">6889320541523148807</guid><pubDate>Fri, 30 Oct 2020 08:02:55 GMT</pubDate><enclosure url="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/42694442254d44b2af51e10372280c83~tplv-k3u1fbpfcp-watermark.image?" length="0" type="false"/></item><item><title><![CDATA[vue 视频播放器 xgplayer 实践]]></title><description><![CDATA[西瓜播放器是一个基于HTML5播放器，它本着一切都是组件化的原则设计了独立可拆卸的 UI 组件。支持自定义ui，在功能上也做了大胆的尝试：摆脱视频加载、缓冲、格式支持对 video 的依赖。尤其是在 mp4 点播上做了较大的努力，让本不支持流式播放的 mp4 能做到分段加载，这…]]></description><link>https://blog.vaebe.cn//article/6887758478178254855</link><guid isPermaLink="false">6887758478178254855</guid><pubDate>Mon, 26 Oct 2020 03:03:04 GMT</pubDate></item><item><title><![CDATA[Nest.js入门、数据库连接]]></title><description><![CDATA[Nest 是一个用于构建高效，可扩展的 Node.js 服务器端应用程序的框架。它使用渐进式 JavaScript，内置并完全支持 TypeScript（但仍然允许开发人员使用纯 JavaScript 编写代码）并结合了 OOP（面向对象编程），FP（函数式编程）和 FRP（函…]]></description><link>https://blog.vaebe.cn//article/6867716871882276871</link><guid isPermaLink="false">6867716871882276871</guid><pubDate>Wed, 02 Sep 2020 02:49:30 GMT</pubDate></item><item><title><![CDATA[原生video，rtmp，rtmp 视频流截图]]></title><description><![CDATA[由于其是只支持传入ing，video(图像、画布或视频)，所以使用 vue-video-player 插件时某些格式的流不是基于video进行播放也就不存在上述的截图，具体可查看 dom 元素。 阿里云Web播放器SDK，同时支持Flash和Html5两种播放技术。 但是其特别…]]></description><link>https://blog.vaebe.cn//article/6864370657103347726</link><guid isPermaLink="false">6864370657103347726</guid><pubDate>Mon, 24 Aug 2020 02:24:16 GMT</pubDate></item><item><title><![CDATA[rtmp、rtsp、flv、mp4、hls视频流测试地址]]></title><description><![CDATA[.rtmp、.rtsp、.flv、 .MP4、 .hls视频流测试地址 在线地址，你绝对值得拥用！！]]></description><link>https://blog.vaebe.cn//article/6855577308271476743</link><guid isPermaLink="false">6855577308271476743</guid><pubDate>Fri, 31 Jul 2020 09:41:48 GMT</pubDate><enclosure url="https://p26-juejin-sign.byteimg.com/tos-cn-i-k3u1fbpfcp/28bb6931ee5847e4bb0503d719c888e4~tplv-k3u1fbpfcp-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5ZSQ6K-X:q75.awebp?rk3s=f64ab15b&amp;x-expires=1774240687&amp;x-signature=7JrSMKVNaIFt9oQryJRAOQaQmZk%3D" length="0" type="false"/></item><item><title><![CDATA[vue根据实时消息，自动播放对应语音]]></title><description><![CDATA[后端实时比对产生预警信息，前端通过WebSocket接收预警信息并播放音频。 首先需要知道 谷歌在 66 版本以后就不允许自动播放音视频及通过函数触发play() 进行播放。 提示表明 用户必须先于浏览器进行交互，就是说用户必须通过点击 移动鼠标 等操作，才能播放音视频。 规则…]]></description><link>https://blog.vaebe.cn//article/6855574111838535693</link><guid isPermaLink="false">6855574111838535693</guid><pubDate>Fri, 31 Jul 2020 09:29:10 GMT</pubDate></item><item><title><![CDATA[flutter 升级版本后 构建失败 Gradle task assembleDebug failed with exit code 1]]></title><description><![CDATA[升级后报错如下建议执行下flutterclean删除构建文件解决办法替换以为文件地址为国内地址flutter/packages/flutter_tools/gradle/resolve_depende]]></description><link>https://blog.vaebe.cn//article/6844904186694369287</link><guid isPermaLink="false">6844904186694369287</guid><pubDate>Fri, 12 Jun 2020 00:56:30 GMT</pubDate></item><item><title><![CDATA[flv.js + vue 播放 .flv流媒体]]></title><description><![CDATA[Flv.js 就是由 bilibili 网站开源的 HTML5 Flash 视频（FLV）播放器，纯原生 JavaScript 开发（ECMAScript 6 编写） ，未用到 Flash。 Flv.js 在 js 中流式解析 flv 文件流，并实时转封装为 fmp4 ，通过 …]]></description><link>https://blog.vaebe.cn//article/6844904164338696199</link><guid isPermaLink="false">6844904164338696199</guid><pubDate>Wed, 20 May 2020 15:38:43 GMT</pubDate></item><item><title><![CDATA[vue实现网站换肤-CSS变量]]></title><description><![CDATA[换肤的实现有很多种，本文使用 css 变量实现 基本思想是： 把所有换肤需要用到的颜色 抽取为变量。使用js统一进行替换。]]></description><link>https://blog.vaebe.cn//article/6844904101654822919</link><guid isPermaLink="false">6844904101654822919</guid><pubDate>Tue, 24 Mar 2020 10:33:36 GMT</pubDate></item></channel></rss>