1 | import baseGetTag from './_baseGetTag.js';
|
---|
2 | import getPrototype from './_getPrototype.js';
|
---|
3 | import isObjectLike from './isObjectLike.js';
|
---|
4 |
|
---|
5 | /** `Object#toString` result references. */
|
---|
6 | var objectTag = '[object Object]';
|
---|
7 |
|
---|
8 | /** Used for built-in method references. */
|
---|
9 | var funcProto = Function.prototype,
|
---|
10 | objectProto = Object.prototype;
|
---|
11 |
|
---|
12 | /** Used to resolve the decompiled source of functions. */
|
---|
13 | var funcToString = funcProto.toString;
|
---|
14 |
|
---|
15 | /** Used to check objects for own properties. */
|
---|
16 | var hasOwnProperty = objectProto.hasOwnProperty;
|
---|
17 |
|
---|
18 | /** Used to infer the `Object` constructor. */
|
---|
19 | var objectCtorString = funcToString.call(Object);
|
---|
20 |
|
---|
21 | /**
|
---|
22 | * Checks if `value` is a plain object, that is, an object created by the
|
---|
23 | * `Object` constructor or one with a `[[Prototype]]` of `null`.
|
---|
24 | *
|
---|
25 | * @static
|
---|
26 | * @memberOf _
|
---|
27 | * @since 0.8.0
|
---|
28 | * @category Lang
|
---|
29 | * @param {*} value The value to check.
|
---|
30 | * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.
|
---|
31 | * @example
|
---|
32 | *
|
---|
33 | * function Foo() {
|
---|
34 | * this.a = 1;
|
---|
35 | * }
|
---|
36 | *
|
---|
37 | * _.isPlainObject(new Foo);
|
---|
38 | * // => false
|
---|
39 | *
|
---|
40 | * _.isPlainObject([1, 2, 3]);
|
---|
41 | * // => false
|
---|
42 | *
|
---|
43 | * _.isPlainObject({ 'x': 0, 'y': 0 });
|
---|
44 | * // => true
|
---|
45 | *
|
---|
46 | * _.isPlainObject(Object.create(null));
|
---|
47 | * // => true
|
---|
48 | */
|
---|
49 | function isPlainObject(value) {
|
---|
50 | if (!isObjectLike(value) || baseGetTag(value) != objectTag) {
|
---|
51 | return false;
|
---|
52 | }
|
---|
53 | var proto = getPrototype(value);
|
---|
54 | if (proto === null) {
|
---|
55 | return true;
|
---|
56 | }
|
---|
57 | var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;
|
---|
58 | return typeof Ctor == 'function' && Ctor instanceof Ctor &&
|
---|
59 | funcToString.call(Ctor) == objectCtorString;
|
---|
60 | }
|
---|
61 |
|
---|
62 | export default isPlainObject;
|
---|