用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,感觉打开一扇新大门

相关推荐
qq_386322691 小时前
华为网路设备学习-21 IGP路由专题-路由过滤(filter-policy)
前端·网络·学习
a濯6 小时前
element plus el-table多选框跨页多选保留
javascript·vue.js
蓝婷儿6 小时前
前端面试每日三题 - Day 32
前端·面试·职场和发展
星空寻流年7 小时前
CSS3(BFC)
前端·microsoft·css3
九月TTS7 小时前
开源分享:TTS-Web-Vue系列:Vue3实现固定顶部与吸顶模式组件
前端·vue.js·开源
CodeCraft Studio8 小时前
数据透视表控件DHTMLX Pivot v2.1发布,新增HTML 模板、增强样式等多个功能
前端·javascript·ui·甘特图
一把年纪学编程8 小时前
【牛马技巧】word统计每一段的字数接近“字数统计”
前端·数据库·word
llc的足迹8 小时前
el-menu 折叠后小箭头不会消失
前端·javascript·vue.js
九月TTS8 小时前
TTS-Web-Vue系列:移动端侧边栏与响应式布局深度优化
前端·javascript·vue.js
曾经的你d8 小时前
【electron+vue】常见功能之——调用打开/关闭系统软键盘,解决打包后键盘无法关闭问题
vue.js·electron·计算机外设