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>
  );
}
相关推荐
mfxcyh1 小时前
npm下载离线依赖包
前端·npm·node.js
waterHBO1 小时前
01 ( chrome 浏览器插件, 立马翻译), 设计
前端·chrome
江城开朗的豌豆1 小时前
Vue组件CSS防污染指南:让你的样式乖乖“宅”在自家地盘!
前端·javascript·vue.js
江城开朗的豌豆1 小时前
Vue组件花式传值:祖孙组件如何愉快地聊天?
前端·javascript·vue.js
浩男孩2 小时前
【🍀新鲜出炉 】十个 “如何”从零搭建 Nuxt3 项目
前端·vue.js·nuxt.js
拉不动的猪3 小时前
pc和移动页面切换的两种基本方案对比
前端·javascript·vue.js
Hilaku3 小时前
前端日志调试也能专业化?我们这样设计日志系统
前端·javascript
李杰同志891633 小时前
iOS moya 实现双token 刷新并重试
前端
花果山总钻风3 小时前
Debian 编译安装 ruby3.2
前端·javascript·debian
前端小巷子3 小时前
跨标签页通信(五):IndexedDB
前端·面试·浏览器