亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

element-ui table組件如何使用render屬性的實現

 更新時間:2019年11月04日 15:07:08   作者:三只萌新  
這篇文章主要介紹了element-ui table組件如何使用render屬性的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

起因:

在使用 element-ui table組件時,由于表列比較多一個個寫特別麻煩,所以想通過將所有表頭定義成一個數組,通過遍歷多方式去實現。這樣解決了手寫很多 el-table-column 的情況。

障礙:

類似于下面自定義表列的樣式,它是通過 slot-scope 去覆蓋 el-table-column 內部slot的樣式實現的。那我們在遍歷表頭數組的時候如何實現呢?

參考:

用過 react 開發(fā)會經常用到 ant design ,其中它的 table 組件是可以接受 render屬性的,下面使用table組件時,只需要定義好,columns(表頭列) data(表的具體數據)即可。整體看起來很簡潔 去渲染自定義的組件的。 點擊查看 antdesign

demo:

codepen demo地址

const columns = [
 {
 title: 'Name',
 dataIndex: 'name',
 render: (text, row, index) => {
  if (index < 4) {
  return <a>{text}</a>;
  }
  return {
  children: <a>{text}</a>,
  props: {
   colSpan: 5,
  },
  };
 },
 }]
 const const data = [
 {
 key: '1',
 name: 'John Brown',
 age: 32,
 tel: '0571-22098909',
 phone: 18889898989,
 address: 'New York No. 1 Lake Park',
 }]
ReactDOM.render(<Table columns={columns} dataSource={data} bordered />, mountNode);

在 Vue 中實現 render 屬性

接下來我們要實現下圖的table的樣式,但是這一次我們采用 render 傳參數的方式

 

思路

  1. 父組件將需要渲染的列表通過 props 傳遞給子組件
  2. 子組件使用 slot 并填充默認渲染的 el-table-column 方式為 prop 渲染 data 中傳遞的值
  3. 子組件通過 slot 將值傳回給父組件,父組件通過 slot-scope 接受到子組件的值,判斷該項是否有 render 屬性,有的話在組件標簽添加 render 屬性返回的 html 去覆蓋 slot 中默認的值。

子組件定義默認值

有了上面的思路,去實現子組件。我們需要知道一點,每個 el-table-column 只是定義了一列的表頭和數據,而 :data="tableList" 中的每項值是定義了一行的數據。所以 el-table-column 是按列來分,data 是按行來分

  • 通過props 去接受表頭列表,數據列表
  • 遍歷表頭數據,并且將 el-table-column 作為默認數據,使用 slot 包裹起來
  • 通過 slot 想父組件傳遞當前項的數據
<template>
 <el-table :data="tableList" style="width:500px">
  <template v-for="item in propList">
  <slot :content="item">
   <el-table-column :key="item.id" :prop="item.prop" :label="item.label"></el-table-column>
  </slot>
  </template>
 </el-table>
</template>
<script>
 export default {
  props:{
   propList:{
   type:Array,
   default:()=>[]
   },
   tableList:{
   type:Array,
   default:()=>[]
   },
  }
 }
</script>

父組件定義

父組件通過 slot-scope 來接受到子組件傳遞過來的數據,然后判斷是否有 render 屬性來確定是否用要去自定義樣式覆蓋默認的 slot

  • 首先看傳遞給子組件的表頭數據,可以看到,第二,三行列表中有一個render屬性,它是一個函數并返回一個 html 的字符串。
  • tableList就是普通的數據,也就是數據的 key 值去渲染對應的數據
  • 圖片這列舉例子,當父組件通過 props 將 {label,prop,id,render} 傳遞給子組件后,子組件有通過 slot 將值傳遞回父組件。
    • 到這里有些人會有疑問,為什么要將數據這樣傳來傳去,因為我們在子組件中定義好了默認樣式,而父組件中需要判斷該值是否需要自定義樣式,去覆蓋子組件中的樣式。
    • 這些自定義樣式就是一開始,在render函數中返回的 html 字符串
    • 為啥 React 直接返回 jsx ,而Vue需要返回 html 字符串,因為react本身就是使用 JSX 來渲染模版的,最終都會通過 babel 編譯成 React.createElement ,而Vue是通過 template 來渲染模版的,這里通過定義 template 模版字符串,最終通過 v-html 來解析
  • 為什么這里有兩個 slot-scope ,第一個是 slot-item 的,組件內部通過 slot-scope 將值傳遞出來。而第二個是 el-table-item 的,ui組件內部同樣將數據通過 slot-scope 傳遞傳來。
  • 通過第一個 slot-scope 拿到 propList 中的定義的 render 函數,通過第二個 slot-scope 拿到 table 組件內部傳遞出來的數據,將數據傳遞給 render 函數去生成自定義模版

最終通過 v-html 去解析生成的字符串模版

<slot-item :propList="propList" :tableList="tableList">
 <template slot-scope="{content}" v-if="content.render">
  <el-table-column :label="content.label">
   <template slot-scope="{$index,row}">
    <div v-html="content.render(row)"></div>
   </template>
  </el-table-column>
 </template>
</slot-item>
 export default {
  components:{
   SlotItem
  },
  data () {
   return { 
    propList:[
     {label:'姓名',prop:'name',id:1},
     {label:'圖片',prop:'pic',id:2,render:({pic})=>{
      return `<img style="width:30px;height:30px" src='${pic}' />`
     }},
     {label:'操作',prop:'operate',id:3,render:({text})=>{
      return `<div style="color:#999">${text}</div>`
     }},
    ],
    tableList:[
     {name:'章三',pic:'https://zh-static-files.oss-cn-hangzhou.aliyuncs.com//karazhan/content/poster/2019/11/16e30c192f6.png',text:'新增'},
     {name:'里斯',pic:'https://zh-static-files.oss-cn-hangzhou.aliyuncs.com//karazhan/content/poster/2019/11/16e30c2797e.png',text:'刪除'},
     {name:'網舞',pic:'https://zh-static-files.oss-cn-hangzhou.aliyuncs.com//karazhan/content/poster/2019/11/16e30c33144.png',text:'跳轉'},
    ]
   }
  }
 }
</script>

結尾

有了render屬性,可以想 ant-design 那樣簡潔的屬性 ui組件模版了!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • VUE Token的失效處理詳解

    VUE Token的失效處理詳解

    這篇文章主要為大家介紹了VUE Token的失效處理,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • Vue3?在<script?setup>里設置組件name屬性的方法

    Vue3?在<script?setup>里設置組件name屬性的方法

    這篇文章主要介紹了Vue3?在<script?setup>里設置組件name屬性的方法,本文通過示例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2023-11-11
  • vue實現購物車加減

    vue實現購物車加減

    這篇文章主要為大家詳細介紹了vue實現購物車加減,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • mpvue構建小程序的方法(步驟+地址)

    mpvue構建小程序的方法(步驟+地址)

    mpvue是一個使用Vue.js開發(fā)小程序的前端框架??蚣芑?Vue.js 核心,這篇文章主要介紹了mpvue構建小程序的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • vue項目刷新當前頁面的三種方式(重載當前頁面數據)

    vue項目刷新當前頁面的三種方式(重載當前頁面數據)

    這篇文章主要介紹了vue項目刷新當前頁面的三種方式(重載當前頁面數據),本文結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • Vue3導出pdf文件詳細方案

    Vue3導出pdf文件詳細方案

    這篇文章主要給大家介紹了關于Vue3導出pdf文件的相關資料,最近項目有個需求,將系統(tǒng)統(tǒng)計的數據生成分析報告,然后可以導出成PDF,這里給大家總結下,需要的朋友可以參考下
    2023-08-08
  • element-ui下拉菜單組件Dropdown的示例代碼

    element-ui下拉菜單組件Dropdown的示例代碼

    這篇文章主要介紹了element-ui下拉菜單組件Dropdown,本文詳細給大家介紹了我遇到的一個最大的坑,通過結合示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • vue中使用echarts以及簡單關系圖的點擊事件方式

    vue中使用echarts以及簡單關系圖的點擊事件方式

    這篇文章主要介紹了vue中使用echarts以及簡單關系圖的點擊事件方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Vue項目中使用setTimeout存在的潛在問題及解決

    Vue項目中使用setTimeout存在的潛在問題及解決

    這篇文章主要介紹了Vue項目中使用setTimeout存在的潛在問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue項目pdf(base64)轉圖片遇到的問題及解決方法

    Vue項目pdf(base64)轉圖片遇到的問題及解決方法

    這篇文章主要介紹了Vue項目pdf(base64)轉圖片遇到的問題及解決方法,需要的朋友可以參考下
    2018-10-10

最新評論