Vue 渲染函數

 

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

 

 

相關文章
相關標籤/搜索