lodash内部方法getData和setData怎么使用

2023-06-14 08:24:34 lodash 方法 setData

这篇“lodash内部方法getData和setData怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“lodash内部方法getData和setData怎么使用”文章吧。

    getData

    getData方法主要是获取方法的元数据metadata。

    getData实现上借助metaMap和noop两个内部方法。

    metaMap

    metaMap方法获取当前环境下的WeakMap对象。

    import WeakMap from './_WeakMap.js';
    var metaMap = WeakMap && new WeakMap;

    WeakMap

    getNative方法和root变量在之前的篇章介绍过,主要是获取环境变量和全局方法。

    源码如下:

    import getNative from './_getNative.js';
    import root from './_root.js';
    var WeakMap = getNative(root, 'WeakMap');

    noop

    noop主要是获取undefined的返回结果。

    源码如下:

    function noop() {}

    getData源码实现

    import metaMap from './_metaMap.js';
    import noop from './noop.js';
    var getData = !metaMap ? noop : function(func) {
      return metaMap.get(func);
    };

    setData

    setData方法可以设置参数

    func
    的元数据。

    参数说明:

    • 参数1:表示要关联元数据的函数

    • 参数2:表示对元数据进行数据处理。

    setData实现上需要借助两个内部方法,分别是:baseSetData和shortOut。

    baseSetData

    baseSetData是setData的基本实现,通过Map对象存储函数与数据的映射关系。

    实现上借助identity方法和metaMap方法,identity方法在之前篇章中介绍过,主要是代表函数一种调用关系,该方法返回参数。metaMap方法主要是调用Map对象,这个方法在上面getData里已经介绍过了。

    import identity from './identity.js';
    import metaMap from './_metaMap.js';
    var baseSetData = !metaMap ? identity : function(func, data) {
      metaMap.set(func, data);
      return func;
    };

    metaMap

    shortOut

    shortOut方法用于按照毫秒范围内的调用数检测热函数,可以创建一个函数,该函数将缩短并调用identity方法。

    实现上通过闭包计数,只有满足调用的时间差小于HOT_SPAN时才会进入后续判断,否则count初始化为0,并且直接返回原函数以及参数关系等。

    在后续处理中只有count满足大于等于HOT_COUNT时直接返回arguments[0]。

    源码如下:

    var HOT_COUNT = 800,
        HOT_SPAN = 16;
    function shortOut(func) {
      var count = 0,
          lastCalled = 0;
      return function() {
        var stamp = nativeNow(),
            remaining = HOT_SPAN - (stamp - lastCalled);
        lastCalled = stamp;
        if (remaining > 0) {
          if (++count >= HOT_COUNT) {
            return arguments[0];
          }
        } else {
          count = 0;
        }
        return func.apply(undefined, arguments);
      };
    }

    setData源码实现

    import baseSetData from './_baseSetData.js';
    import shortOut from './_shortOut.js';
    var setData = shortOut(baseSetData);

    相关文章