国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

vue封裝el-table表格組件

這篇具有很好參考價(jià)值的文章主要介紹了vue封裝el-table表格組件。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

先上效果圖:
vue封裝el-table表格組件,vue,js,Element UI,vue.js,javascript,前端

本文包含了具名插槽、作用域插槽、jsx語法三種:

Render.vue(很重要,必須有):

<script>
export default {
  name: "FreeRender",
  functional: true,
  props: {
    scope:Object,
    render: Function
  },
  render: (h, ctx) => {
    console.log(222,ctx.props.render);// 通過打印會(huì)發(fā)現(xiàn)render函數(shù)會(huì)自動(dòng)用h函數(shù)進(jìn)行包裹
    return ctx.props.render ? ctx.props.render( ctx.props.scope) : "";
  }
};
</script>

Table.vue

<template>
  <div>
    <el-table :data="tableData" style="width: 100%" 
    :stripe="stripe" :border="border" :size="size"
    v-loading="loading"
    @selection-change="handleSelectionChange"
    >
    <!-- 是否支持復(fù)選 -->
    <el-table-column v-if="isSelection" width="55" type="selection" />
      <el-table-column
        :prop="item.param"
        :label="item.label"
        v-for="(item, index) in tableColumns"
        :key="index"
        :sortable="item.sortable"
        :width="item.width"
      >
        <template slot-scope="scope">
           <div v-if="item.render2">
             <Render
             :scope='scope.row'
             :render="item.render2"
            >
            </Render>
           </div>
          <slot v-else-if="item.slotName" :name="item.slotName" :row2="scope.row"></slot>
          <span v-else>{{scope.row[item.param]}}</span>
        </template>
      </el-table-column>
      <!-- 操作 -->
      <el-table-column v-if="tableOperation.label" :label="tableOperation.label">
        <template slot-scope="scope">
            <slot :name="tableOperation.param" :scope="scope">
              <el-button
                size="small"
                v-for="(item, index) in tableOperation.btnList"
                :key="index"
                @click="handleClick(scope.row, item.type)">
                {{item.label}}
              </el-button>
            </slot>
        </template>
      </el-table-column>
    </el-table>
   
  </div>
</template>
<script>
import Render from "@/components/Render";
export default {
  name: "Table",
  props: {
    tableColumns: {
      type: Array,
      required: true,
      default: () => {
        return []
      }
    },
    tableData: {
      type: Array,
      required: true,
      default: () => {
        return []
      }
    },
    tableOperation: {
      type: Object,
      default: () => {
        return {}
      }
    },
    stripe: {
      type: Boolean,
      default: true
    },
    border: {
      type: Boolean,
      default: true
    },
    size: {
      type: String,
      default: 'small'
    },
    loading: {
      type: Boolean,
      default: false
    },
    isSelection: {
      type: Boolean,
      default: false,
    }
  },
  components:{
    Render,
  },
  data() {
    return {
      h:'',
    }
  },
  methods: {
    handleClick(row, type) {
      this.$emit('handleClick', row, type)
    },
    handleSelectionChange(val) {
      this.$emit('handleSelectionChange', val)
    }
  }

使用Table組件文章來源地址http://www.zghlxwxcb.cn/news/detail-830787.html

//html
    <Table
      :tableData="tableData"
      :isSelection="true"
      :tableColumns="tableColumns"
      :tableOperation="tableOperation"
      @handleClick="handleClick"
      @handleSelectionChange="handleSelectionChange"
    >
     <template #infoInput="scope">
       <el-input v-model="scope.row2.info"></el-input>
      </template>
    
    </Table>
// data & methods
 tableData: [
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀區(qū)金沙江路 1518 弄",
          age: "1",
          progress:50,
          info:'好好學(xué)習(xí)',
        },
        {
          date: "2016-05-04",
          name: "王小虎",
          address: "上海市普陀區(qū)金沙江路 1517 弄",
          age: "0",
          progress:60,
          info:'天天向上',
        },
        {
          date: "2016-05-01",
          name: "王小虎",
          address: "上海市普陀區(qū)金沙江路 1519 弄",
          age: "1",
          progress:70,
          info:'為人名服務(wù)',
        },
        {
          date: "2016-05-03",
          name: "王小虎",
          address: "上海市普陀區(qū)金沙江路 1516 弄",
          age: "1",
          progress:80,
          info:'為人名服務(wù)2',
        },
      ],

      tableColumns: [
        {
          param: "date",
          label: "日期",
          width: "100",

        },
        {
          param: "name",
          label: "姓名",
          width: "100",
        },
        {
          param: "address",
          label: "地址",
        },
        {
          param: "age",
          label: "性別",
          render2: (row) => {
            return (
              <el-radio-group v-model={row.age}>
                <el-radio label={"0"}></el-radio>
                <el-radio label={"1"}></el-radio>
              </el-radio-group>
            );
          },
        },
        {
          param:'progress',
          label:'進(jìn)度',
          render2:(row)=>{
            return(
            <el-progress percentage={row.progress}></el-progress>
            )
          }

        },{
          param:'info',
          label:'信息',
          slotName:'infoInput',

        }
      ],
      tableOperation: {
        label: "操作",
        btnList: [
          {
            label: "刪除",
            type: "warning",
            param: "del",
            type: "del",
          },
          {
            label: "新增",
            type: "primary",
            param: "add",
            type: "add",
          },
        ],
      },
      
  handleClick(val, type) {
      console.log("val1", val);
      console.log("type", type);
    },
    handleSelectionChange(val) {
      console.log("val2", val);
    },     

到了這里,關(guān)于vue封裝el-table表格組件的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • element-ui的table實(shí)現(xiàn)滾動(dòng)加載,涵el-table組件封裝一份

    element-ui的table實(shí)現(xiàn)滾動(dòng)加載,涵el-table組件封裝一份

    重點(diǎn)就是 a d d R o l l L i s t e n e r addRollListener a d d R o l l L i s t e n e r 函數(shù),想快點(diǎn)弄上去看效果的直接弄這個(gè)函數(shù)吧 如果不在mounted中則一定要this.$nextTick(() = this.addRollListener()) 示例代碼 如果你把上面的看過了;只需要在 a d d R o l l L i s t e n e r addRollListener a d d R o l l L i s t e

    2023年04月08日
    瀏覽(34)
  • vue(element ui )el-table樹形表格展示及數(shù)據(jù)對(duì)齊

    vue(element ui )el-table樹形表格展示及數(shù)據(jù)對(duì)齊

    注意點(diǎn): el-table配置里 row-key 必須是唯一性 :tree-props=“{ children: ‘relatedPartyChild’ , hasChildren: ‘hasChildren’ }” children配置為后端返回的節(jié)點(diǎn)字段即可

    2024年02月16日
    瀏覽(30)
  • vue element-ui表格(el-table)數(shù)據(jù)導(dǎo)出execl文件

    功能實(shí)現(xiàn):element UI 的el-table數(shù)據(jù)導(dǎo)出為execl文件 使用到插件:xlsx、file-saver exportExecl.js 代碼如下: 頁面代碼如下:

    2024年02月14日
    瀏覽(30)
  • vue使用Element UI時(shí),el-table表格整行操作單選

    vue使用Element UI時(shí),el-table表格整行操作單選

    需求:表格復(fù)選修改為單選,只可選擇一個(gè);不滿足條件的不可勾選;可進(jìn)行整行操作 注意使用的方法. 需求由復(fù)選改為單選后, 左上角全選框要進(jìn)行隱藏 ,復(fù)選框也變成單選框,這里是通過css樣式進(jìn)行調(diào)整的 勾選復(fù)選框的select和整行操作的row-click可以共用同一個(gè)方法,

    2024年02月14日
    瀏覽(27)
  • 隨手記:使用sortable.js 實(shí)現(xiàn)element-ui el-table 表格上下拖拽排序

    需求場(chǎng)景: 表格可以實(shí)現(xiàn)上下拖拽row實(shí)現(xiàn)新排序 首先,安裝sortable.js ?引入表格排? 全局掛在組件 使用頁面引入 使用sortable.js表格一定要有唯一的row-key,一般綁定的是id,不然拖拽會(huì)不生效 data聲明 sortableContainer: null,為的是后面如果有需要可以做銷毀操作 ? 因?yàn)槲疫@里是表

    2024年02月22日
    瀏覽(29)
  • 解決vue-electron element-UI中el-table表格不顯示

    解決vue-electron element-UI中el-table表格不顯示

    問題:element-UI官網(wǎng)上el-table組件,引入自己項(xiàng)目的時(shí)候表格不顯示。 解決方案: 修改.electron-vuewebpack.renderer.config.js 將 修改為 即可解決。

    2024年02月16日
    瀏覽(37)
  • Vue3 - Element Plus 表格組件 “手動(dòng)“ 取消/選中勾選列,并同步更新表格復(fù)選框 UI 狀態(tài)(el-table 表格組件中,通過代碼手動(dòng)控制某個(gè)列的選中與取消勾選,并且復(fù)選框跟著變)

    Vue3 - Element Plus 表格組件 “手動(dòng)“ 取消/選中勾選列,并同步更新表格復(fù)選框 UI 狀態(tài)(el-table 表格組件中,通過代碼手動(dòng)控制某個(gè)列的選中與取消勾選,并且復(fù)選框跟著變)

    網(wǎng)上基本上都是全部取消勾選的教程,沒有僅對(duì)單獨(dú)列操作的教程。 本文 實(shí)現(xiàn)了在 vue3 + element plus 組件庫中,對(duì) “某一個(gè)” 或 “幾個(gè)單獨(dú)” 列進(jìn)行勾選/取消(手動(dòng)操作表格復(fù)選框),并且讓表格復(fù)選框自動(dòng)同步選中狀態(tài), 完美解決刪除表格列勾選的數(shù)據(jù)后,選中和取消

    2024年02月03日
    瀏覽(131)
  • Vue 中 Element UI 的 el-table 組件實(shí)現(xiàn)動(dòng)態(tài)表頭和內(nèi)容

    在 Vue 中使用 Element UI 的 el-table 組件時(shí),為了實(shí)現(xiàn)動(dòng)態(tài)表頭(包括第一層表頭及其下的嵌套表頭或子表頭)。需要后端返回的數(shù)據(jù)結(jié)構(gòu)能夠體現(xiàn)表頭層級(jí)關(guān)系以及對(duì)應(yīng)的數(shù)據(jù)結(jié)構(gòu)相匹配。這樣的數(shù)據(jù)通常是一個(gè)嵌套數(shù)組,每個(gè)表頭單元可能包含自身的列信息以及它的子表頭和

    2024年01月20日
    瀏覽(31)
  • Element Plus二次封裝el-table、可編輯表格

    Element Plus二次封裝el-table、可編輯表格

    一、需求 在后臺(tái)管理項(xiàng)目中,可以顯而易見的見到表格組件,為了方便我們會(huì)把表格組件進(jìn)行二次封裝,即方便了開發(fā),也方便了維護(hù)。 2023年04月01日更新單元格編輯功能 擴(kuò)展 el-table 擴(kuò)展【表格動(dòng)態(tài)列展示】 整合版本,附帶查詢,分頁,表頭自定義展示,等其他功能。 注

    2024年02月07日
    瀏覽(28)
  • vue使用Element UI時(shí),el-table表格整行操作單選禁選并隱藏全選框

    vue使用Element UI時(shí),el-table表格整行操作單選禁選并隱藏全選框

    需求:表格復(fù)選修改為單選,只可選擇一個(gè);不滿足條件的不可勾選;可進(jìn)行整行操作 注意使用的方法. 需求由復(fù)選改為單選后, 左上角全選框要進(jìn)行隱藏 ,復(fù)選框也變成單選框,這里是通過css樣式進(jìn)行調(diào)整的 勾選復(fù)選框的select和整行操作的row-click可以共用同一個(gè)方法,

    2024年02月13日
    瀏覽(23)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包