Vue 推薦在絕大多數狀況下使用模板來建立你的 HTML。然而在一些場景中,你真的須要 JavaScript 的徹底編程的能力。這時你能夠用渲染函數,它比模板更接近編譯器。css
一 項目結構vue
二 App組件編程
<template> <div id="app"> <fruit fruitName="Durian" :level="2"> very delicious! </fruit> </div> </template> <script> import "./components/Fruit.js"; export default { name: "App" }; </script> <style lang="scss"> </style>
三 Fruit組件app
import Vue from "vue"; import Durian from "./Durian.vue"; import Mongo from "./Mongo.vue"; Vue.component("fruit", { props: { fruitName: { type: String, required: true }, level: { type: Number, required: true } }, data() { return { shop: "水果店" }; }, render(createElement) { const { fruitName, level, shop, $slots, nativeClickHandler } = this; const ele = fruitName === "Durian" ? Durian : Mongo; return createElement( ele, { class: { favorFruit: true }, style: "color:gold;font-style:italic;", attrs: { id: "favorFruit" }, nativeOn: { click: nativeClickHandler }, scopedSlots: { shop(props) { return createElement("h6", shop); } } }, [createElement("h" + level, fruitName), $slots.default] ); }, methods: { nativeClickHandler() { console.log("native click"); } } });
四 Durian組件函數
<template> <div> <slot/> <slot name="shop"/> </div> </template> <script> export default { name: "Durian" }; </script>
五 Mongo組件ui
<template> <div> <slot/> <slot name="shop"/> </div> </template> <script> export default { name: "Mango" }; </script>
六 運行效果this