Avue排坑之表格頭搜索

實(shí)現(xiàn)效果
image.png

官方介紹--自定義表頭函數(shù):renderHeader


image.png
具體實(shí)現(xiàn)

首先對表格的配置數(shù)組columns進(jìn)行循環(huán)對進(jìn)行按需添加
然后先添加a-popover彈窗书斜, 最后添加搜索框以及查詢按鈕

   columns.forEach((element) => {
        if (element.label === '詢價(jià)單號') {
        element.renderHeader = (h, { column, $index }) => {
            const content = h('div', [
              h('div', [
                h('a-input', {
                  // style: { minWidth: '100px', maxWidth: '200px'},
                  // 彈窗中的搜索欄
                  props: { value: this.searchFormData[column.property], allowClear: true },
                  on: {
                    change: (e) => {
                      this.searchFormData[column.property] = e.target.value;
                    }
                  }
                })
              ]),
              h('div', [
                h(
                  'el-button',
                  {
                    // 彈窗中的搜索按鈕
                    style: { marginLeft: '62%', marginTop: '5px' },
                    props: {
                      icon: 'el-icon-search',
                      type: 'primary',
                      size: 'mini'
                    },
                    on: {
                      click: () => {
                        this.handleSearch({
                          [column.property]: this.searchFormData[column.property] // 接口傳參
                        });
                      }
                    }
                  },
                  '查詢'
                )
              ])
            ]);
            const popover = h(
              // 展開彈窗
              'a-popover',
              {
                props: { placement: 'top', trigger: 'click' },
                scopedSlots: {
                  content: (props) => content
                }
              },
              [
                h('span', column.label),
                h('el-button', {
                  on: {
                    click: (event) => {
                      // 展開彈窗清空this.searchFormData查詢條件
                      Object.keys(this.searchFormData).forEach(
                        (key) => (this.searchFormData[key] = '')
                      );
                    }
                  },
                  props: { icon: 'el-icon-search', type: 'text' }
                })
              ]
            );
            return popover;
          };
        }
      });
擴(kuò)展--- 日期、select 捍岳、input等多類型篩選
image.png
 import * as components from './renderHeader'; // 引入components 組件
 columns.forEach((element) => {
        this.DataDir.forEach((ite) => {  //this.DataDir為字段數(shù)組狮惜, bizDic 字典key淤袜。儲(chǔ)存頂部下拉數(shù)據(jù)
          if (element.bizDic === ite.name) {
            element.dicData = ite.arr;
          }
        });
       if ( element.label === '詢價(jià)單號' || element.label === '審批狀態(tài)' ) {
          element.renderHeader = (h, { column, $index }) => {
            let type = element.type
            if (!element.type || element.type === 'default') {
              type = 'input';
            }
            if (element.bizDic) {
              type = 'select';
            }
            const component = components[type] &&components[type](h, column.property, this.searchFormData, element, this);
            const content = h('div', [
              h('div', [component]), // 唯一區(qū)別點(diǎn)在于動(dòng)態(tài)組件component
           // --------------------------------------------------------下方代碼保持不變--------------------------------------------
              h('div', [
                h(
                  'el-button',
                  {
                    // 彈窗中的搜索按鈕
                    style: { marginLeft: '62%', marginTop: '5px' },
                    props: {
                      icon: 'el-icon-search',
                      type: 'primary',
                      size: 'mini'
                    },
                    on: {
                      click: () => {
                        this.handleSearch({
                          [column.property]: this.searchFormData[column.property] // 接口傳參
                        });
                      }
                    }
                  },
                  '查詢'
                )
              ])
            ]);
          const popover = h(
              // 展開彈窗
              'a-popover',
              {
                props: { placement: 'top', trigger: 'click' },
                scopedSlots: {
                  content: (props) => content
                }
              },
              [
                h('span', column.label),
                h('el-button', {
                  on: {
                    click: (event) => {
                      // 展開彈窗清空this.searchFormData查詢條件
                      Object.keys(this.searchFormData).forEach(
                        (key) => (this.searchFormData[key] = '')
                      );
                    }
                  },
                  props: { icon: 'el-icon-search', type: 'text' }
                })
              ]
            );
            return popover;
          };
        }
renderHeader.js組件
import moment from 'moment';
import Vue from 'vue';
export const input = (h, prop, form, column, that) => {
  return h('a-input', {
    props: { value: form[prop], allowClear: true },
    on: {
      change: (e) => {
        Vue.set(form, prop, e.target.value);
      }
    }
  });
};
export const link = (h, prop, form, column, that) => {
  return h('a-input', {
    props: { value: form[prop], allowClear: true },
    on: {
      change: (e) => {
        Vue.set(form, prop, e.target.value);
      }
    }
  });
};

export const select = (h, prop, form, column, that) => {
  return h(
    'a-select',
    {
      style: { width: '100%' },
      props: {
        value: form[prop],
        allowClear: true
      },
      on: {
        change: (val) => {
          Vue.set(form, prop, val);
        }
      }
    },
    column.dicData &&
      column.dicData.map((item) => {
        return h(
          'a-select-option',
          {
            props: {
              value: item.value
            }
          },
          [item.label]
        );
      })
  );
};

export const datetime = (h, prop, form, column, that) => {
  return h('a-range-picker', {
    props: {
      value: form[prop] ? form[prop].map((item) => moment(item, 'x')) : [],
      allowClear: true,
      format: 'YYYY-MM-DD HH:mm:ss',
      showTime: { format: 'HH:mm:ss' },
      placeholder: [that.$t('i18n_components_start_time'), that.$t('i18n_components_end_time')]
    },
    on: {
      change: (val) => {
        Vue.set(
          form,
          prop,
          val.map((item) => item.format('x'))
        );
      }
    }
  });
};
export const date = (h, prop, form, column, that) => {
  return h('a-range-picker', {
    props: {
      value: form[prop] ? form[prop].map((item) => moment(item, 'x')) : [],
      allowClear: true,
      format: 'YYYY-MM-DD',
      placeholder: [that.$t('i18n_components_start_time'), that.$t('i18n_components_end_time')]
    },
    on: {
      change: (val) => {
        Vue.set(
          form,
          prop,
          [val[0].startOf('day'), val[1].endOf('day')].map((item) => item.format('x'))
        );
      }
    }
  });
};

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末妙黍,一起剝皮案震驚了整個(gè)濱河市赘被,隨后出現(xiàn)的幾起案子是整,更是在濱河造成了極大的恐慌,老刑警劉巖民假,帶你破解...
    沈念sama閱讀 211,561評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浮入,死亡現(xiàn)場離奇詭異,居然都是意外死亡羊异,警方通過查閱死者的電腦和手機(jī)事秀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來野舶,“玉大人易迹,你說我怎么就攤上這事∑降溃” “怎么了睹欲?”我有些...
    開封第一講書人閱讀 157,162評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長一屋。 經(jīng)常有香客問我窘疮,道長,這世上最難降的妖魔是什么陆淀? 我笑而不...
    開封第一講書人閱讀 56,470評論 1 283
  • 正文 為了忘掉前任考余,我火速辦了婚禮,結(jié)果婚禮上轧苫,老公的妹妹穿的比我還像新娘楚堤。我一直安慰自己疫蔓,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評論 6 385
  • 文/花漫 我一把揭開白布身冬。 她就那樣靜靜地躺著衅胀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪酥筝。 梳的紋絲不亂的頭發(fā)上滚躯,一...
    開封第一講書人閱讀 49,806評論 1 290
  • 那天,我揣著相機(jī)與錄音嘿歌,去河邊找鬼掸掏。 笑死,一個(gè)胖子當(dāng)著我的面吹牛宙帝,可吹牛的內(nèi)容都是我干的丧凤。 我是一名探鬼主播,決...
    沈念sama閱讀 38,951評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼步脓,長吁一口氣:“原來是場噩夢啊……” “哼愿待!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起靴患,我...
    開封第一講書人閱讀 37,712評論 0 266
  • 序言:老撾萬榮一對情侶失蹤仍侥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后鸳君,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體农渊,經(jīng)...
    沈念sama閱讀 44,166評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評論 2 327
  • 正文 我和宋清朗相戀三年相嵌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了腿时。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片况脆。...
    茶點(diǎn)故事閱讀 38,643評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡饭宾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出格了,到底是詐尸還是另有隱情看铆,我是刑警寧澤,帶...
    沈念sama閱讀 34,306評論 4 330
  • 正文 年R本政府宣布盛末,位于F島的核電站弹惦,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏悄但。R本人自食惡果不足惜棠隐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望檐嚣。 院中可真熱鬧助泽,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至诫睬,卻和暖如春煞茫,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背摄凡。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評論 1 266
  • 我被黑心中介騙來泰國打工续徽, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人亲澡。 一個(gè)月前我還...
    沈念sama閱讀 46,351評論 2 360
  • 正文 我出身青樓炸宵,卻偏偏與公主長得像,于是被迫代替她去往敵國和親谷扣。 傳聞我的和親對象是個(gè)殘疾皇子土全,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評論 2 348

推薦閱讀更多精彩內(nèi)容