AI取名大师 | 使得 uni-app 兼容 vue3 同名简写语法糖的 vite 插件

关于 AI 取名大师

借助豆包通义千问DeepSeek 等 AI 大模型,为您的宝宝、宠物、店铺、网名、笔名、项目、产品、服务、文章等取一个专业、有意义的名字😄。


开源地址:👉GitCode(国内友好)👈、👉GitHub👈 技术组合:Bun.jsElysia.jsuni-app 体验地址:AI取名大师(H5版)、小程序搜索取名大师


特别注明:本系列文章仅为实战经验分享,并记录开发过程中碰到的问题😄,如有不足之处欢迎随时留言提出。


📣 同名简写语法

这是 vue 3.4+ 后更新的语法糖,如果属性名变量名完全一致,Vue 允许你简写,详见官方文档

写法 等价
v-bind:text="text" 完整写法
:text="text" v-bind 简写
:text 同名简写(implicit value)

示例:

html 复制代码
<script setup>
	const message = "Hello";
	const active = true;
</script>

<template>
  	<Comp :message :active />
	<!--甚至可以这样写-->
	<Comp v-bind="{ message, active }" />
</template>

😔 在小程序中不支持

同名简写语法,用过就觉得很香,习惯后怎么舍得改回来。可惜小程序(尤其是微信小程序)不支持该语法糖,使得编译不通过,只能一个个把同名简写改成传统模式😔。

🔧 搞一个插件

功能

专门为 uni-app 修补 Vue3 同名简写,就是 Vue SFC 进入 uni-app 小程序编译之前,用一个自定义 Vite 插件把 :text 自动转换为 :text="text"

原理简介

  • Vue 编译器对 :text 是合法的,因为它是 Vue3 的同名简写;
  • uni-app 的小程序编译器(特别是微信)不支持,会报错;
  • 我们可以在 Vite 阶段 预处理 .vue 文件的 template 源码:
    • 找到所有 :<attr> 且没有 = 的情况;
    • 转换成 :<attr>="<attr>"

设计原则

  • ✔ 只处理
相关推荐
徐小夕25 分钟前
JitWord Office预览引擎:如何用Vue3+Node.js打造丝滑的PDF/Excel/PPT嵌入方案
前端·vue.js·github
晴殇i34 分钟前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
BER_c1 小时前
前端权限校验最佳实践:一个健壮的柯里化工具函数
前端·javascript
敲敲敲敲暴你脑袋1 小时前
写个添加注释的vscode插件
javascript·typescript·visual studio code
SuperEugene2 小时前
后台权限与菜单渲染:基于路由和后端返回的几种实现方式
前端·javascript·vue.js
csdn飘逸飘逸2 小时前
Autojs基础-全局函数与变量(globals)
javascript
KKKK2 小时前
手写Promise,从测试用例的角度理解
javascript
青青家的小灰灰2 小时前
迈向全栈新时代:SSR/SSG 原理、Next.js 架构与 React Server Components (RSC) 实战
前端·javascript·react.js
SuperEugene2 小时前
弹窗与抽屉组件封装:如何做一个全局可控的 Dialog 服务
前端·javascript·vue.js
青青家的小灰灰2 小时前
透视 React 内核:Diff 算法、合成事件与并发特性的深度解析
前端·javascript·react.js