国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

vue中render函數的使用詳解

2024-05-06 15:28:46
字體:
來源:轉載
供稿:網友

render函數

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

render方法的實質就是生成template模板;

通過調用一個方法來生成,而這個方法是通過render方法的參數傳遞給他的;

通過這三個參數,可以生成一個完整的模板

官網實例

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

說明

區別:

沒有顯示的模板內容,而是通過render方法生成 使用了createElement方法

createElement方法,通過render函數的參數傳遞進來,有三個參數:

第一個參數(必要參數):主要用于提供DOM的html內容,類型可以是字符串、對象或函數 第二個參數(類型是對象,可選):用于設置這個DOM的一些樣式、屬性、傳的組件的參數、綁定事件之類 第三個參數(類型是數組,數組元素類型是VNode,可選):主要是指該結點下還有其他結點,用于設置分發的內容,包括新增的其他組件。注意,組件樹中的所有VNode必須是唯一的

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

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

 <div class="btn btn-success" v-if="type === 'success'">{{ text }}</div> <div class="btn btn-danger" v-else-if="type === 'danger'">{{ text }}</div> <div class="btn btn-warning" v-else-if="type === 'warning'">{{ text }}</div>

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

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

首先render函數生成的內容相當于template的內容,故使用render函數時,在.vue文件中需要先把template標簽去掉。只保留邏輯層。

export default { props: {  type: {   type: String,   default: 'normal'  },  text: {   type: String,   default: 'normal'  } }, computed: {  tag() {   switch (this.type) {    case 'success':     return 1;    case 'danger':     return 2;    case 'warning':     return 3;    default:     return 1;   }  } }, render(h) {  return h('div', {   class: {    btn: true,    'btn-success': this.type === 'success',    'btn-danger': this.type === 'danger',    'btn-warning': this.type === 'warning'   },   domProps: {    innerText: this.text   },   on: {    click: this.handleClick   }  }); }, methods: {  handleClick() {   console.log('-----------------------');   console.log('do something');  } }};            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 宜都市| 永仁县| 平谷区| 高碑店市| 泽库县| 淮阳县| 西昌市| 烟台市| 托里县| 吴江市| 东乡县| 定安县| 都匀市| 永川市| 宜昌市| 绥芬河市| 玉山县| 黄浦区| 瓮安县| 无棣县| 哈尔滨市| 佛冈县| 丰原市| 盐边县| 新郑市| 拉孜县| 左云县| 衡东县| 安化县| 中山市| 安宁市| 四子王旗| 亳州市| 衢州市| 岗巴县| 灵山县| 科技| 增城市| 称多县| 方山县| 龙海市|