[d565449] | 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;
|
---|