el-tree的属性render-content自定义样式不生效

需求是想要自定义展示el-tree的项,官网有一个:render-content属性,用的时候发现不管是使用class还是style,样式都没有生效,还会报一个错,怎么个事呢,后来发现控制台还会报一个错"vue.js:5129 [Vue warn]: Failed to resolve directive: if",

原来是在 Vue 3 中的 JSX 里,像v-if、v-show这类指令不能直接使用,而是要通过 JavaScript 条件表达式来替代,果然修改完之后就生效了。

修改前:

javascript 复制代码
   <el-tree
      :data="data"
      show-checkbox
      node-key="id"
      default-expand-all
      :expand-on-click-node="false"
      :render-content="renderContent">
    </el-tree>
    
   renderContent(h, { data }) {
      return (
        <span class="custom-tree-node">
          <span>
            <span
              v-if="data.isTickAgen === 1"
              style="display: inline-block; width: 14px; height: 14px; line-height: 14px;font-size:10px; text-align: center; background-color: #ffffff; color: #1472FF;border:1px solid #1472FF; border-radius: 50%; margin-right: 2px;"
            >
              证
            </span>
            {data?.data?.agenCode}
            {data?.data?.agenName}
          </span>
        </span>
      )
    }

修改后:

javascript 复制代码
renderContent(h, { data }) {
  return (
    <span class="custom-tree-node">
      <span>
        {data.isTickAgen === 1 && (
          <span
            style="display: inline-block; width: 14px; height: 14px; line-height: 14px;font-size:10px; text-align: center; background-color: #ffffff; color: #1472FF;border:1px solid #1472FF; border-radius: 50%; margin-right: 2px;"
          >
            证
          </span>
        )}
        {data?.data?.agenCode}
        {data?.data?.agenName}
      </span>
    </span>
  );
}
相关推荐
前端的日常7 分钟前
以下代码,那一部分运行快
前端
GeGarron9 分钟前
Drawing:专注高效画图,让每一次创作都值得被珍藏
前端
梨子同志9 分钟前
Vue v-model 指令详解
前端·vue.js
杨进军9 分钟前
简易实现 React 页面初次渲染
前端·react.js·前端框架
血舞之境11 分钟前
同名类引发问题:没见过世面导致遇见各种诡异的问题
前端
杨进军11 分钟前
实现 React 多个原生标签子节点渲染
前端·react.js·前端框架
前端的日常12 分钟前
AI 工具中,经常提到的 mcp 是什么,有哪些与前端方向结合的场景?
前端
嘉小华12 分钟前
Android 协程全景式深度解析:第四章 Flow响应式流
android·前端
Tina_晴14 分钟前
【基础篇】Promise初体验+案例分析(上)
前端·javascript·面试
7ayl15 分钟前
闭包
javascript