* @private * @param {*} obj * @return {boolean} Returns true if `obj` is an array or array-like object (NodeList, Arguments, * String ...)
(obj)
| 346 | * String ...) |
| 347 | */ |
| 348 | function isArrayLike(obj) { |
| 349 | |
| 350 | // `null`, `undefined` and `window` are not array-like |
| 351 | if (obj == null || isWindow(obj)) return false; |
| 352 | |
| 353 | // arrays, strings and jQuery/jqLite objects are array like |
| 354 | // * jqLite is either the jQuery or jqLite constructor function |
| 355 | // * we have to check the existence of jqLite first as this method is called |
| 356 | // via the forEach method when constructing the jqLite object in the first place |
| 357 | if (isArray(obj) || isString(obj) || (jqLite && obj instanceof jqLite)) return true; |
| 358 | |
| 359 | // Support: iOS 8.2 (not reproducible in simulator) |
| 360 | // "length" in obj used to prevent JIT error (gh-11508) |
| 361 | var length = 'length' in Object(obj) && obj.length; |
| 362 | |
| 363 | // NodeList objects (with `item` method) and |
| 364 | // other objects with suitable length characteristics are array-like |
| 365 | return isNumber(length) && |
| 366 | (length >= 0 && ((length - 1) in obj || obj instanceof Array) || typeof obj.item === 'function'); |
| 367 | |
| 368 | } |
| 369 | |
| 370 | /** |
| 371 | * @ngdoc function |
no test coverage detected