feat: 在单一vue组件内实现模板复用(非jsx版本)
parent
9d9ff346c7
commit
15908d0543
@ -0,0 +1,29 @@
|
|||||||
|
export function creatTemplateReuse() {
|
||||||
|
let render = [];
|
||||||
|
|
||||||
|
const DefineTemplate = {
|
||||||
|
setup(_, { slots }) {
|
||||||
|
console.log(slots);
|
||||||
|
// render = slots.default;
|
||||||
|
for (let key in slots) {
|
||||||
|
render.push({
|
||||||
|
slotName: key,
|
||||||
|
render: slots[key],
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return () => {};
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
const useTemplate = (props) => {
|
||||||
|
console.log(props);
|
||||||
|
let renderList = [];
|
||||||
|
props.slotName.forEach((name) => {
|
||||||
|
let chooseItem = render.find((item) => item.slotName === name);
|
||||||
|
renderList.push(chooseItem.render(props));
|
||||||
|
});
|
||||||
|
return renderList;
|
||||||
|
};
|
||||||
|
|
||||||
|
return [DefineTemplate, useTemplate];
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue