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>
  );
}
相关推荐
天蓝色的鱼鱼1 小时前
前端开发者的组件设计之痛:为什么我的组件总是难以维护?
前端·react.js
codingandsleeping2 小时前
使用orval自动拉取swagger文档并生成ts接口
前端·javascript
石金龙2 小时前
[译] Composition in CSS
前端·css
白水清风3 小时前
微前端学习记录(qiankun、wujie、micro-app)
前端·javascript·前端工程化
Ticnix3 小时前
函数封装实现Echarts多表渲染/叠加渲染
前端·echarts
用户22152044278003 小时前
new、原型和原型链浅析
前端·javascript
阿星做前端3 小时前
coze源码解读: space develop 页面
前端·javascript
叫我小窝吧3 小时前
Promise 的使用
前端·javascript
NBtab3 小时前
Vite + Vue3项目版本更新检查与页面自动刷新方案
前端
天天扭码3 小时前
来全面地review一下Flex布局(面试可用)
前端·css·面试