Vue2+Element-ui后台系统常用js方法

el-dialog弹框关闭清空form表单并清空验证

javascript 复制代码
cancelDialog(diaLog, formRef) {
  this[diaLog] = false
  if (formRef) {
    this.$refs[formRef].resetFields()
  }
}

页面使用:

javascript 复制代码
<el-dialog 
  :visible.sync="addSubsidyDialog.dialog" 
  @close="cancelDialog(addSubsidyDialog.dialog, 'subsidyRef')"
>
   <el-form ref="subsidyRef"></el-form>
</el-dialog>

@close传参说明:

需要关闭的弹窗this、关闭后需要清空的form表单

el-date-picker限制结束时间不能小于开始时间

template:

javascript 复制代码
<div>
  <el-date-picker
    v-model="innerBeginDate"
    type="date"
    placeholder="开始日期"
    value-format="yyyy-MM-dd"
    :picker-options="pickerStartOptions(innerEndDate)"
    :editable="false"
  />
  <span class="ml10 mr10">-</span>
  <el-date-picker
    v-model="innerEndDate"
    type="date"
    placeholder="结束日期"
    value-format="yyyy-MM-dd"
    :picker-options="pickerEndOptions(innerBeginDate)"
    :editable="false"
  />
</div>

方法:

javascript 复制代码
pickerStartOptions(endTime) {
  return {
    disabledDate(time) {
      if (endTime) {
        return time.getTime() > new Date(endTime).getTime()
      }
    }
  }
},
pickerEndOptions(startTime) {
  return {
    disabledDate(time) {
      if (startTime) {
        return time.getTime() < new Date(startTime).getTime()
      }
    }
  }
},

表单筛选项重置

javascript 复制代码
resetQuery() {
  this.queryParam = this.$options.data().queryParam
  this.handleQuery()
}

以下方法自行修改

queryParam为 form表单筛选对象

handleQuery为 重置后重新搜索

过滤掉对象空值

javascript 复制代码
filterNonEmptyValues(obj) {
  return Object.fromEntries(
    Object.entries(obj).filter(
      ([_, value]) =>
        value !== null &&
        value !== undefined &&
        !(typeof value === 'string' && value.trim() === '') &&
        !(Array.isArray(value) && value.length === 0)
    )
  )
}

页面使用:

javascript 复制代码
const obj = {
  a: '',
  b: [],
  c: null,
  d: undefined,
  f: 123,
  e: 789,
  q: '  '
};

const filteredObj = filterNonEmptyValues(obj);
console.log(filteredObj);

输出:
{
  f: 123,
  e: 789
}

感谢你的阅读,如对你有帮助请收藏+关注!

只分享干货实战精品从不啰嗦!!!

如某处不对请留言评论,欢迎指正~

博主可收徒、常玩QQ飞车,可一起来玩玩鸭~

相关推荐
上优2 分钟前
Vue3纯前端同源跨窗口通信移动AGV小车
前端·vue.js·状态模式
h_k100862 分钟前
Chrome 插件开发入门技术文章大纲
前端·chrome
一只小阿乐3 分钟前
vue-router 的实现原理
前端·javascript·vue.js·路由·vue-router
小圣贤君3 分钟前
小说写作中的时间轴管理:基于 Vue 3 的事序图技术实现
vue.js·electron·写作·甘特图·时间轴·事序图
Zz_waiting.3 分钟前
案例开发 - 日程管理 - 第七期
开发语言·前端·javascript·vue.js·html·路由
writeone4 分钟前
9-10关于JS初学产生的问题
开发语言·javascript·ecmascript
一只小风华~7 分钟前
Vue:事件处理机制详解
前端·javascript·vue.js·typescript·前端框架
dy17174 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
2501_915918418 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂8 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库