需求是想要自定义展示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>
);
}