Skip to content
This repository has been archived by the owner on Apr 12, 2024. It is now read-only.

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(isArrayLike): recognize empty instances of an Array subclass
Browse files Browse the repository at this point in the history
Fixes #13560
gkalpak committed Jan 7, 2016

Unverified

This commit is not signed, but one or more authors requires that any commit attributed to them is signed.
1 parent f7eab8d commit a8f5f1d
Showing 2 changed files with 27 additions and 5 deletions.
3 changes: 2 additions & 1 deletion src/Angular.js
Original file line number Diff line number Diff line change
@@ -215,7 +215,8 @@ function isArrayLike(obj) {
// NodeList objects (with `item` method) and
// other objects with suitable length characteristics are array-like
return isNumber(length) &&
(length >= 0 && (length - 1) in obj || typeof obj.item == 'function');
(length >= 0 && ((length - 1) in obj || obj instanceof Array) || typeof obj.item == 'function');

}

/**
29 changes: 25 additions & 4 deletions test/AngularSpec.js
Original file line number Diff line number Diff line change
@@ -1218,17 +1218,38 @@ describe('angular', function() {
});

it('should return true if passed a nodelist', function() {
var nodes = document.body.childNodes;
expect(isArrayLike(nodes)).toBe(true);
var nodes1 = document.body.childNodes;
expect(isArrayLike(nodes1)).toBe(true);

var nodes2 = document.getElementsByTagName('nonExistingTagName');
expect(isArrayLike(nodes2)).toBe(true);
});

it('should return false for objects with `length` but no matching indexable items', function() {
var obj = {
var obj1 = {
a: 'a',
b:'b',
length: 10
};
expect(isArrayLike(obj)).toBe(false);
expect(isArrayLike(obj1)).toBe(false);

var obj2 = {
length: 0
};
expect(isArrayLike(obj2)).toBe(false);
});

it('should return true for empty instances of an Array subclass', function() {
function ArrayLike() {}
ArrayLike.prototype = Array.prototype;

var arrLike = new ArrayLike();
expect(arrLike.length).toBe(0);
expect(isArrayLike(arrLike)).toBe(true);

arrLike.push(1, 2, 3);
expect(arrLike.length).toBe(3);
expect(isArrayLike(arrLike)).toBe(true);
});
});

0 comments on commit a8f5f1d

Please sign in to comment.