ElTableColumn添加搜索归纳功能

这次给大家带来ElTableColumn添加搜索归纳功能,ElTableColumn添加搜索归纳功能的注意事项有哪些,下面就是实战案例,一起来看一下。

公司有一个新的需求,点击ElTableColumn的头部可以进行搜索,这个功能同事已经做出来了,但是使用有些不方便,自己就打算封装成一个组件,学习一下。

ElTableColumn本来是这个样子的:

ElTableColumn添加搜索归纳功能

要做成的是这个样子:

ElTableColumn添加搜索归纳功能

我直接就放代码了,挨着挨着说明太多了。

代码的结构:

ElTableColumn添加搜索归纳功能

组件

                     {{fomatMethod(scope.row[prop])}}              import moment from "moment";export default { name: "el-table-column-pro", props: {  prop: {   type: String  },  label: {   type: String  },  width: {   type: Number  },  renderType: {   type: String,   validator: value => ["date", "input", "select"].includes(value)  },  placeholder: {   type: String  },  rederWidth: {   type: String,   default: "230px"  },  param: {   type: String,   default: ""  },  startDate: {   type: String  },  endDate: {   type: String  },  selectList: {   type: Array  },  isClear: {   type: Boolean,   default:true  },  visible: {   type: Boolean,   default: true  },  filterIcon: {   type: String,   default: "el-icon-search"  },  callback: {   type: Function  },  formatter: {   type: Function,   default:(row, column, cellValue)=>cellValue  },  align:{   type:String   },  headerAlign:{   type:String  } }, data() {  return {   formatD:this.filterIcon  }; },  methods: {  fomatMethod(value){   return this.formatter('','',value)  },    renderHeader(createElement, { column, $index }) {   switch (this.renderType) {    case "date":     return this.renderDate(createElement, { column, $index });    case "input":     return this.rederInput(createElement, { column, $index });         case "select":     return this.rederSelect(createElement, { column, $index });        default:     return column.label;   }  },  rederInput(createElement, { column, $index }) {   return createElement(    "p",    {     class: "filters",     style: {      color: column.color     }    },    [     createElement(      "el-popover",      {       props: {        placement: "bottom",        width: "200",        trigger: "click"       }      },      [       createElement("el-input", {        props: {         placeholder: this.placeholder,         value: this.param        },        nativeOn: {         keyup: event => {          if (event.keyCode === 13) {           this.$emit("update:param", event.target.value);           this.callback && this.callback();          }         }        },        on: {         blur: event => {          this.$emit("update:param", event.target.value);          this.callback && this.callback();         }        }       }),       createElement(        "span",        {         slot: "reference"        },        [         column.label,         createElement("i", {          class: this.filterIcon,          style: {           marginLeft: "4px"          }         })        ]       )      ]     )    ]   );  },  rederSelect(createElement, { column, $index }) {   return createElement(    "p",    {     class: "filters",     style: {      color: column.color     }    },    [     createElement(      "el-popover",      {       props: {        placement: "bottom",        width: "200",        trigger: "click"       }      },      [       createElement(        "el-select",        {         props: {          placeholder: this.placeholder,          value: this.param,          clearable: this.isClear         },         on: {          input: value => {           this.$emit("update:param", value);           this.callback && this.callback();          }         }        },        [         this.selectList.map(item => {          return createElement("el-option", {           props: {            value: item.value,            label: item.label           }          });         })        ]       ),       createElement(        "span",        {         slot: "reference"        },        [         column.label,         createElement("i", {          class: this.filterIcon,          style: {           marginLeft: "4px"          }         })        ]       )      ]     )    ]   );  },  renderDate(createElement, { column, $index }) {   return createElement(    "p",    {     class: "filters"    },    [     createElement(      "el-popover",      {       props: {        placement: "bottom",        width: this.rederWidth,        trigger: "click"       }      },      [       createElement("el-date-picker", {        props: {         placeholder: this.placeholder,         value: this.value,         type: "daterange",         rangeSeparator:"至",         startPlaceholder:"开始日期",         endPlaceholder:"结束日期",        },        style: {         width: this.rederWidth        },        on: {         input: value => {          if (value) {           const startDate = moment(value[0]).format("YYYY-MM-DD");           const endDate = moment(value[1]).format("YYYY-MM-DD");           this.$emit("update:startDate", startDate);           this.$emit("update:endDate", endDate);           this.callback && this.callback();          }         }        }       }),       createElement(        "span",        {         slot: "reference"        },        [         column.label,         createElement("i", {          class: this.filterIcon,          style: {           marginLeft: "4px"          }         })        ]       )      ]     )    ]   );  } }};import ElTableColumnPro from './ElTableColumnPro'ElTableColumnPro.install = function(Vue) { Vue.component(ElTableColumnPro.name, ElTableColumnPro);};export default ElTableColumnPro;

登录后复制

安装

import ElTableColumnPro from 'components/ElTableColumnPro/index' .........Vue.use(ElTableColumnPro)

登录后复制

使用

                     

登录后复制

                                  
{{scope.row.content}}

登录后复制                     

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

前端如何向后台传送Json数据

使用Post方法传递json参数有哪些方式

以上就是ElTableColumn添加搜索归纳功能的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2765166.html

(0)
上一篇 2025年3月8日 10:47:27
下一篇 2025年3月7日 19:30:54

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JS常用函数总结归纳

    这次给大家带来JS常用函数总结归纳,使用JS常用函数的注意事项有哪些,下面就是实战案例,一起来看一下。 数组扁平化 数组扁平化有很多方法,但最终最好的方法就是递归,实现一个指定深度的扁平化方法,这样基本的套路都会了解。 function f…

    编程技术 2025年3月8日
    200
  • beforeEach实现路由跳转验证功能

    这次给大家带来beforeEach实现路由跳转验证功能,beforeEach实现路由跳转验证的注意事项有哪些,下面就是实战案例,一起来看一下。 路由跳转前做一些验证,比如登录验证(未登录去登录页),是网站中的普遍需求。对此,vue-rout…

    编程技术 2025年3月8日
    200
  • vue实战项目里常用知识点归纳

    这次给大家带来vue实战项目里常用知识点归纳,vue实战项目的注意事项有哪些,下面就是实战案例,一起来看一下。 【相关推荐:vue面试题(2020)】 vue的底层原理? vue组件之间的通信? JS中判断数据类型的方法有几种? 最常见的判…

    编程技术 2025年3月8日
    200
  • vue裁切预览组件功能的实现步骤

    这篇文章主要介绍了vue裁切预览组件功能的实现代码,本文通过实例代码相结合的形式给大家介绍的非常详细,具有一定的参考借鉴价值,感兴趣的朋友跟随脚本之家小编一起学习吧 vue版本裁切工具,包含预览功能 最终效果: qiuyaofan.gith…

    2025年3月8日
    200
  • node实现的爬虫功能

    这篇文章主要介绍了node实现的爬虫功能,结合实例形式分析了nodejs实现爬虫功能的步骤与相关操作技巧,需要的朋友可以参考下 本文实例讲述了node实现的爬虫功能。分享给大家供大家参考,具体如下: node是服务器端的语言,所以可以像py…

    2025年3月8日
    200
  • Vue 实现树形视图数据功能

    这篇文章主要介绍了关于实现vue 实现树形视图数据功能,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 利用简单的树形视图实现,熟悉了组件的递归使用 这是模拟的树形图数据 let all={   name:’all’,   c…

    2025年3月8日 编程技术
    200
  • 基于Vue实现拖拽功能

    这篇文章主要为大家详细介绍了vue实现拖拽功能,拖动方块进行移动,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文实例为大家分享了Vue实现拖拽功能的具体代码,供大家参考,具体内容如下 效果图: HTML代码:            …

    2025年3月8日
    200
  • vue做出全选与反选功能

    这次给大家带来vue做出全选与反选功能,vue做出全选与反选功能的注意事项有哪些,下面就是实战案例,一起来看一下。 全选功能可以说是前端开发中非常常见的一个功能,以前的项目开发用jQuery开发比较多。最近在使用vue前端框架重构之前的项目…

    2025年3月8日
    200
  • ElTableColumn扩展方法详解

    这次给大家带来ElTableColumn扩展方法详解,ElTableColumn扩展的注意事项有哪些,下面就是实战案例,一起来看一下。 公司有一个新的需求,点击ElTableColumn的头部可以进行搜索,这个功能同事已经做出来了,但是使用…

    2025年3月8日
    200
  • PHP图片简单上传功能详解

    这篇文章主要为大家详细介绍了php图片简单上传功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。 以下是代码:    登录后复制 总结: php 上传图片,一般都使用move_uploaded_file方法保存在服务器上。但如果一个网…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论