lodash库_.chunk、_.pick、_.omit、_.cloneDeep、_.debounce方法

lodash 模块化、高性能的 JavaScript 实用工具库。官方文档:https://www.lodashjs.com

1.对数组进行分组 _.chunk(array, [size=1])

使用场景,如移动端页面一行能放5个元素,总共7条数据,将一维数组转为二维数组,让一个数组只有5个成员

参数:arr表示要分组的数组,num表示一个分组里面放几个元素

arr: [{a: 1},{a: 2},{a: 3},{a: 4},{a: 5},{a: 6},{a: 7}],

2.选中和过滤对象的属性_.pick(Object,[prop])和_.omit()

_.pick(Object,[prop]) :第一个参数数据源,必须是对象,第二个参数需要获取的属性(可以是数组形式),返回新的数组

_.omit():和pick相反,排除某个数据

3.防抖处理

_.debounce(fn,wait,[options]) : [options]是一个对象,可以设置定时器各种配置

leading: true延时开始前是否调用,默认false

trailing: false延时结束后是否调用,默认true

注意:防抖函数在vue中的使用,在data中定义函数并调用_.debounce()函数后,进行return。

直接在methods里面写不能被正常调用,因为_.debounce()主要是接收一个返回值,然后再执行返回函数。

4. 数据进行深拷贝 _.cloneDeep(obj)

使用场景:如vuex中对state数据是引用数据类型的修改,直接通过obj.a = 1的形式修改发现没有触发页面渲染

javascript 复制代码
<template>
  <button style="height:30px" @click="onDebounce">按钮</button>
</template>
<script>
import _ from "lodash";

export default {
  name: "Form",
  data() {
    const onDebounce = _.debounce(function() {
          console.log("按钮触发了---");
        },
        1000,
        {
          leading: false,
          trailing: true
        })
    return {
      onDebounce,
      arr: [
        { a: 1 },
        { a: 2 },
        { b: 3 },
        { b: 4 },
        { c: 5 },
        { c: 6 },
        { d: 7 }
      ],
      obj:{
        name:'lmf',
        age: 23
      }
    };
  },
  mounted(){
    console.log(_.chunk(this.arr, 5));
    console.log(_.pick(this.obj, ['name']));
    console.log(_.omit(this.obj, ['name']));
    let obj2 = _.cloneDeep(this.obj)
    obj2.name = "limingfang"
    console.log(this.obj,obj2);
  },
};
</script>
相关推荐
翻滚吧键盘12 分钟前
vue绑定一个返回对象的计算属性
前端·javascript·vue.js
苦夏木禾16 分钟前
js请求避免缓存的三种方式
开发语言·javascript·缓存
超级土豆粉25 分钟前
Turndown.js: 优雅地将 HTML 转换为 Markdown
开发语言·javascript·html
乆夨(jiuze)1 小时前
记录H5内嵌到flutter App的一个问题,引发后面使用fastClick,引发后面input输入框单击无效问题。。。
前端·javascript·vue.js
小彭努力中1 小时前
141.在 Vue 3 中使用 OpenLayers Link 交互:把地图中心点 / 缩放级别 / 旋转角度实时写进 URL,并同步解析显示
前端·javascript·vue.js·交互
小飞悟2 小时前
前端高手才知道的秘密:Blob 居然这么强大!
前端·javascript·html
code_YuJun2 小时前
Promise 基础使用
前端·javascript·promise
Codebee2 小时前
OneCode自主UI设计体系:架构解析与核心实现
前端·javascript·前端框架
邢同学爱折腾2 小时前
当前端轮播图遇上Electron: 变身一款丝滑的 图片查看器
javascript·electron
xiguolangzi2 小时前
vue3+element-plus el-table列的显隐、列宽 持久化
前端·javascript·vue.js