用transform给vue加点功能

用vue这么长时间,最近突然有一个想法。就是简化属性传false值的写法

属性值为true

给组件传true的时候,可以只写属性不写值,比如下面这样

vue 复制代码
<template>
	<el-link type="primary">primary</el-link>
</template>

这个el-link有个属性名为 underline 默认为true,如果想要设置为false, 需要显示传递 :underline="false"

但是如果一个属性需要传值true,却可以如下简写

vue 复制代码
<template>
	<el-link type="primary" disabled>primary</el-link>
</template>

但是传false时却无法简写,必须显示设置

简化false传值

vue 复制代码
<template>
	<el-link type="primary" !underline>primary</el-link>
</template>

目标是在属性前面添加一个感叹号表示给这个属性传false。这样对于常量true/false只需要添加或者移除属性前面的感叹号。但是vue本身貌似没有这个功能,又应该如何实现呢

nodeTransforms

这里以vite项目为例,在vite项目中使用@vitejs/plugin-vue 支持vue文件的构建。而这里就可以添加自定义的节点转换器把!underline 转换成 :underline="false"

typescript 复制代码
import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import falseTransform from "false-transform"

export default defineConfig({
  plugins: [
    vue({
      template: {
        compilerOptions: {
          nodeTransforms: [falseTransform],
        },
      },
    }),
  ],
});

在这个transform当中,会找到所有感叹号开头的属性,并改成v-bind指令属性


真是第一次使用自定义transform,感觉打开一扇新大门

相关推荐
VT.馒头9 分钟前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
css趣多多20 分钟前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
-凌凌漆-29 分钟前
【vue】pinia中的值使用 v-model绑定出现[object Object]
javascript·vue.js·ecmascript
C澒41 分钟前
前端整洁架构(Clean Architecture)实战解析:从理论到 Todo 项目落地
前端·架构·系统架构·前端框架
C澒1 小时前
Remesh 框架详解:基于 CQRS 的前端领域驱动设计方案
前端·架构·前端框架·状态模式
Charlie_lll1 小时前
学习Three.js–雪花
前端·three.js
onebyte8bits1 小时前
前端国际化(i18n)体系设计与工程化落地
前端·国际化·i18n·工程化
C澒1 小时前
前端分层架构实战:DDD 与 Clean Architecture 在大型业务系统中的落地路径与项目实践
前端·架构·系统架构·前端框架
BestSongC1 小时前
行人摔倒检测系统 - 前端文档(1)
前端·人工智能·目标检测
0思必得02 小时前
[Web自动化] Selenium处理滚动条
前端·爬虫·python·selenium·自动化