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

发布于:2025-06-21 ⋅ 阅读:(16) ⋅ 点赞:(0)

需求是想要自定义展示el-tree的项,官网有一个:render-content属性,用的时候发现不管是使用class还是style,样式都没有生效,还会报一个错,怎么个事呢,后来发现控制台还会报一个错“vue.js:5129 [Vue warn]: Failed to resolve directive: if”,
原来是在 Vue 3 中的 JSX 里,像v-if、v-show这类指令不能直接使用,而是要通过 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>
      )
    }

修改后:

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>
  );
}

网站公告

今日签到

点亮在社区的每一天
去签到