国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Vue render深入窺探之謎

Amos / 2693人閱讀

摘要:僅對于組件,用于監(jiān)聽原生事件,而不是組件內(nèi)部使用觸發(fā)的事件。注意,你無法對中的賦值,因為已經(jīng)自動為你進行了同步。

簡介

在使用Vue進行開發(fā)的時候,大多數(shù)情況下都是使用template進行開發(fā),使用template簡單、方便、快捷,可是有時候需要特殊的場景使用template就不是很適合。因此為了很好使用render函數(shù),我決定深入窺探一下。各位看官如果覺得下面寫的有不正確之處還望看官指出,你們與我的互動就是寫作的最大動力。

場景

官網(wǎng)描述的場景當(dāng)我們開始寫一個通過 level prop 動態(tài)生成 heading 標簽的組件,你可能很快想到這樣實現(xiàn):

Vue.component("anchored-heading", {
  template: "#anchored-heading-template",
  props: {
    level: {
      type: Number,
      required: true
    }
  }
})

在這種場景中使用 template 并不是最好的選擇:首先代碼冗長,為了在不同級別的標題中插入錨點元素,我們需要重復(fù)地使用

雖然模板在大多數(shù)組件中都非常好用,但是在這里它就不是很簡潔的了。那么,我們來嘗試使用 render 函數(shù)重寫上面的例子:

Vue.component("anchored-heading", {
  render: function (createElement) {
    return createElement(
      "h" + this.level,   // tag name 標簽名稱
      this.$slots.default // 子組件中的陣列
    )
  },
  props: {
    level: {
      type: Number,
      required: true
    }
  }
})

簡單清晰很多!簡單來說,這樣代碼精簡很多,但是需要非常熟悉 Vue 的實例屬性。在這個例子中,你需要知道當(dāng)你不使用 slot 屬性向組件中傳遞內(nèi)容時,比如 anchored-heading 中的 Hello world!,這些子元素被存儲在組件實例中的 $slots.default中。

createElement參數(shù)介紹

接下來你需要熟悉的是如何在 createElement 函數(shù)中生成模板。這里是 createElement 接受的參數(shù):

createElement(
  // {String | Object | Function}
  // 一個 HTML 標簽字符串,組件選項對象,或者
  // 解析上述任何一種的一個 async 異步函數(shù),必要參數(shù)。
  "div",

  // {Object}
  // 一個包含模板相關(guān)屬性的數(shù)據(jù)對象
  // 這樣,您可以在 template 中使用這些屬性。可選參數(shù)。
  {
    // (詳情見下一節(jié))
  },

  // {String | Array}
  // 子節(jié)點 (VNodes),由 `createElement()` 構(gòu)建而成,
  // 或使用字符串來生成“文本節(jié)點”。可選參數(shù)。
  [
    "先寫一些文字",
    createElement("h1", "一則頭條"),
    createElement(MyComponent, {
      props: {
        someProp: "foobar"
      }
    })
  ]
)
深入 data 對象

有一件事要注意:正如在模板語法中,v-bind:class 和 v-bind:style ,會被特別對待一樣,在 VNode 數(shù)據(jù)對象中,下列屬性名是級別最高的字段。該對象也允許你綁定普通的 HTML 特性,就像 DOM 屬性一樣,比如 innerHTML (這會取代 v-html 指令)。

{
  // 和`v-bind:class`一樣的 API
  "class": {
    foo: true,
    bar: false
  },
  // 和`v-bind:style`一樣的 API
  style: {
    color: "red",
    fontSize: "14px"
  },
  // 正常的 HTML 特性
  attrs: {
    id: "foo"
  },
  // 組件 props
  props: {
    myProp: "bar"
  },
  // DOM 屬性
  domProps: {
    innerHTML: "baz"
  },
  // 事件監(jiān)聽器基于 `on`
  // 所以不再支持如 `v-on:keyup.enter` 修飾器
  // 需要手動匹配 keyCode。
  on: {
    click: this.clickHandler
  },
  // 僅對于組件,用于監(jiān)聽原生事件,而不是組件內(nèi)部使用
  // `vm.$emit` 觸發(fā)的事件。
  nativeOn: {
    click: this.nativeClickHandler
  },
  // 自定義指令。注意,你無法對 `binding` 中的 `oldValue`
  // 賦值,因為 Vue 已經(jīng)自動為你進行了同步。
  directives: [
    {
      name: "my-custom-directive",
      value: "2",
      expression: "1 + 1",
      arg: "foo",
      modifiers: {
        bar: true
      }
    }
  ],
  // Scoped slots in the form of
  // { name: props => VNode | Array }
  scopedSlots: {
    default: props => createElement("span", props.text)
  },
  // 如果組件是其他組件的子組件,需為插槽指定名稱
  slot: "name-of-slot",
  // 其他特殊頂層屬性
  key: "myKey",
  ref: "myRef"
}
條件渲染

既然熟讀以上api接下來咱們就來點實戰(zhàn)。
之前這樣寫

//HTML
我被你發(fā)現(xiàn)啦!!!
//js //組件形式 Vue.component("vv-isshow", { props:["show"], template:"
我被你發(fā)現(xiàn)啦2!!!
", }); var vm = new Vue({ el: "#app", data: { isShow:true } });

render這樣寫

//HTML
我被你發(fā)現(xiàn)啦3!!!
//js //組件形式 Vue.component("vv-isshow", { props:{ show:{ type: Boolean, default: true } }, render:function(h){ if(this.show ) return h("div",this.$slots.default); }, }); var vm = new Vue({ el: "#app", data: { isShow:true } });
列表渲染

之前是這樣寫的,而且v-for 時template內(nèi)必須被一個標簽包裹

//HTML
//js //組件形式 Vue.component("vv-aside", { props:["list"], methods:{ handelClick(item){ console.log(item); } }, template:"
{{item.txt}}
", //template:"
{{item.txt}}
",錯誤 }); var vm = new Vue({ el: "#app", data: { list: [{ id: 1, txt: "javaScript", odd: true }, { id: 2, txt: "Vue", odd: false }, { id: 3, txt: "React", odd: true }] } });

render這樣寫

//HTML
//js //側(cè)邊欄 Vue.component("vv-aside", { render: function(h) { var _this = this, ayy = this.list.map((v) => { return h("div", { "class": { odd: v.odd }, attrs: { title: v.txt }, on: { click: function() { return _this.handelClick(v); } } }, v.txt); }); return h("div", ayy); }, props: { list: { type: Array, default: () => { return this.list || []; } } }, methods: { handelClick: function(item) { console.log(item, "item"); } } }); var vm = new Vue({ el: "#app", data: { list: [{ id: 1, txt: "javaScript", odd: true }, { id: 2, txt: "Vue", odd: false }, { id: 3, txt: "React", odd: true }] } });
v-model

之前的寫法

//HTML
//js //input Vue.component("vv-models", { props: ["txt"], template: "

看官你輸入的是:{{txtcout}}

", computed: { txtcout:{ get(){ return this.txt; }, set(val){ this.$emit("input", val); } } } }); var vm = new Vue({ el: "#app", data: { txt: "", } });

render這樣寫

//HTML
//js //input Vue.component("vv-models", { props: { txt: { type: String, default: "" } }, render: function(h) { var self=this; return h("div",[h("p","你猜我輸入的是啥:"+this.txt),h("input",{ on:{ input(event){ self.$emit("input", event.target.value); } } })] ); }, }); var vm = new Vue({ el: "#app", data: { txt: "", } });
總結(jié)

render函數(shù)使用的是JavaScript 的完全編程的能力,在性能上是占用絕對的優(yōu)勢,小編只是對它進行剖析。至于實際項目你選擇那種方式進行渲染依舊需要根據(jù)你的項目以及實際情況而定。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/94195.html

相關(guān)文章

  • 2017-08-02 前端日報

    摘要:前端日報精選浮點數(shù)精度之謎前端面試必備基本排序算法從賀老微博引出的遍歷器加速那些奧秘進階之深入理解數(shù)據(jù)雙向綁定全棧天中文深入理解筆記用模塊封裝代碼前端架構(gòu)經(jīng)驗分享周二放送自制知乎專欄譯在大型應(yīng)用中使用的五個技巧掘金開發(fā)指南眾成 2017-08-02 前端日報 精選 JavaScript 浮點數(shù)精度之謎前端面試必備——基本排序算法從賀老微博引出的遍歷器(Iterators)加速那些奧秘J...

    Worktile 評論0 收藏0
  • 窺探react事件

    摘要:解決問題為了解決上述問題,先來了解下的事件,事件是合成事件,為原生事件的一個子集,僅僅是進行了一個跨瀏覽器的封裝。參考本文部分參考自事件初探 寫在前面 本文源于本人在學(xué)習(xí)react過程中遇到的一個問題;本文內(nèi)容為本人的一些的理解,如有不對的地方,還請大家指出來。本文是講react的事件,不是介紹其api,而是猜想一下react合成事件的實現(xiàn)方式 遇到的問題 class EventTes...

    劉厚水 評論0 收藏0
  • 窺探React - 源碼分析

    摘要:所謂知其然還要知其所以然本文將分析的部分源碼包括組件初始渲染的過程和組件更新的過程在這之前假設(shè)讀者已經(jīng)對有一定了解知道區(qū)別了解生命周期事務(wù)批量更新大致概念等如何分析源碼代碼架構(gòu)預(yù)覽首先我們找到在上的地址把版本的源碼下來觀察它的整體架構(gòu)這 所謂知其然還要知其所以然. 本文將分析 React 15-stable的部分源碼, 包括組件初始渲染的過程和組件更新的過程.在這之前, 假設(shè)讀者已經(jīng):...

    instein 評論0 收藏0
  • 深入理解js

    摘要:詳解十大常用設(shè)計模式力薦深度好文深入理解大設(shè)計模式收集各種疑難雜癥的問題集錦關(guān)于,工作和學(xué)習(xí)過程中遇到過許多問題,也解答過許多別人的問題。介紹了的內(nèi)存管理。 延遲加載 (Lazyload) 三種實現(xiàn)方式 延遲加載也稱為惰性加載,即在長網(wǎng)頁中延遲加載圖像。用戶滾動到它們之前,視口外的圖像不會加載。本文詳細介紹了三種延遲加載的實現(xiàn)方式。 詳解 Javascript十大常用設(shè)計模式 力薦~ ...

    caikeal 評論0 收藏0
  • 深入Vue.js從源碼開始(三)

    摘要:數(shù)據(jù)驅(qū)動一個核心思想是數(shù)據(jù)驅(qū)動。發(fā)生了什么從入口代碼開始分析,我們先來分析背后發(fā)生了哪些事情。函數(shù)最后判斷為根節(jié)點的時候設(shè)置為,表示這個實例已經(jīng)掛載了,同時執(zhí)行鉤子函數(shù)。這里注意表示實例的父虛擬,所以它為則表示當(dāng)前是根的實例。 數(shù)據(jù)驅(qū)動 Vue.js 一個核心思想是數(shù)據(jù)驅(qū)動。所謂數(shù)據(jù)驅(qū)動,是指視圖是由數(shù)據(jù)驅(qū)動生成的,我們對視圖的修改,不會直接操作 DOM,而是通過修改數(shù)據(jù)。它相比我們傳...

    lentrue 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<