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

相关推荐
white-persist8 分钟前
Python实例方法与Python类的构造方法全解析
开发语言·前端·python·原型模式
新中地GIS开发老师1 小时前
Cesium 军事标绘入门:用 Cesium-Plot-JS 快速实现标绘功能
前端·javascript·arcgis·cesium·gis开发·地理信息科学
Superxpang1 小时前
前端性能优化
前端·javascript·vue.js·性能优化
左手吻左脸。1 小时前
解决el-select因为弹出层层级问题,不展示下拉选
javascript·vue.js·elementui
左手吻左脸。1 小时前
Element UI表格中根据数值动态设置字体颜色
vue.js·ui·elementui
李白的故乡1 小时前
el-tree-select名字
javascript·vue.js·ecmascript
Rysxt_1 小时前
Element Plus 入门教程:从零开始构建 Vue 3 界面
前端·javascript·vue.js
隐含1 小时前
对于el-table中自定义表头中添加el-popover会弹出两个的解决方案,分别针对固定列和非固定列来隐藏最后一个浮框。
前端·javascript·vue.js
大鱼前端1 小时前
Turbopack vs Webpack vs Vite:前端构建工具三分天下,谁将胜出?
前端·webpack·turbopack
你的人类朋友1 小时前
先用js快速开发,后续引入ts是否是一个好的实践?
前端·javascript·后端