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 条件表达式来替代,果然修改完之后就生效了。
修改前:
<el-tree:data="data"show-checkboxnode-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><spanv-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 && (<spanstyle="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>);
}