首頁 > web前端 > js教程 > vue中render函數在什麼情況下適合使用?

vue中render函數在什麼情況下適合使用?

不言
發布: 2018-10-11 17:17:07
轉載
4206 人瀏覽過

這篇文章帶給大家的內容是關於vue中render函數在什麼情況下適合使用?有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

render函數

vue透過 template 來建立你的 HTML。但是,在特殊情況下,這種寫死的模式無法滿足需求,必須需要js的程式設計能力。此時,需要用render來建立HTML。

什麼情況下適合使用render函數

在一次封裝一套通用按鈕元件的工作中,按鈕有四個樣式(success、error、warning、default )。首先,你可能會想到如下實作

  <div class="btn btn-success" v-if="type === &#39;success&#39;">{{ text }}</div>
  <div class="btn btn-danger" v-else-if="type === &#39;danger&#39;">{{ text }}</div>
  <div class="btn btn-warning" v-else-if="type === &#39;warning&#39;">{{ text }}</div>
登入後複製

這樣寫在按鈕樣式少的時候完全沒有問題,但是試想,如果需要的按鈕樣式有十多個。那麼template寫死的方式就顯得很無力了。遇上類似這樣的情況,使用render函數可以說最優選擇了。

根據實際情況改寫按鈕元件

首先render函數產生的內容相當於template的內容,故使用render函數時,在.vue檔案中需要先把template標籤去掉。只保留邏輯層。

export default {
  props: {
    type: {
      type: String,
      default: &#39;normal&#39;
    },
    text: {
      type: String,
      default: &#39;normal&#39;
    }
  },
  computed: {
    tag() {
      switch (this.type) {
        case &#39;success&#39;:
          return 1;
        case &#39;danger&#39;:
          return 2;
        case &#39;warning&#39;:
          return 3;
        default:
          return 1;
      }
    }
  },
  render(h) {
    return h(&#39;p&#39;, {
      class: {
        btn: true,
        &#39;btn-success&#39;: this.type === &#39;success&#39;,
        &#39;btn-danger&#39;: this.type === &#39;danger&#39;,
        &#39;btn-warning&#39;: this.type === &#39;warning&#39;
      },
      domProps: {
        innerText: this.text
      },
      on: {
        click: this.handleClick
      }
    });
  },
  methods: {
    handleClick() {
      console.log(&#39;-----------------------&#39;);
      console.log(&#39;do something&#39;);
    }
  }
};
登入後複製

根據元件化思維,能抽像出來的東西絕不寫死在邏輯上。這裡的clickHandle函數可以根據按鈕的type型別觸發不同的邏輯,就不多敘述了。

然後在父元件呼叫

<Button type="danger" text="test"></Button>
登入後複製

使用jsx

是的,要記住每個參數的類型同用法,按序傳參實在是太麻煩了。那其實可以用jsx來優化這個繁瑣的流程。

  render() {
    return (
      <div
        class={{
          btn: true,
          &#39;btn-success&#39;: this.type === &#39;success&#39;,
          &#39;btn-danger&#39;: this.type === &#39;danger&#39;,
          &#39;btn-warning&#39;: this.type === &#39;warning&#39;
        }}
        onClick={this.handleClick}>
        {this.text}
      </div>
    );
  },
登入後複製

以上是vue中render函數在什麼情況下適合使用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:segmentfault.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
JavaScript鉤子函數是什麼?
來自於 1970-01-01 08:00:00
0
0
0
怎麼實作 JavaScript點與圓的位置關係
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板