Fix hasObjectSpliceBug implementations of _#pop, _#shift, and _#splice.

Former-commit-id: 91a3bc259c85bd269c3d895b66204bdc4d158827
This commit is contained in:
John-David Dalton
2012-12-16 00:14:00 -08:00
parent cb9e044cb3
commit cca4c4be80
2 changed files with 17 additions and 12 deletions

View File

@@ -4399,16 +4399,18 @@
// avoid array-like object bugs with `Array#shift` and `Array#splice`
// in Firefox < 10 and IE < 9
if (hasObjectSpliceBug) {
each(['shift', 'splice'], function(methodName) {
var func = lodash.prototype[methodName];
each(['pop', 'shift', 'splice'], function(methodName) {
var func = arrayRef[methodName],
isSplice = methodName == 'splice';
lodash.prototype[methodName] = function() {
var value = this.__wrapped__,
result = func.apply(this, arguments);
result = func.apply(value, arguments);
if (value.length === 0) {
delete value[0];
}
return result;
return isSplice ? new lodash(result) : result;
};
});
}

View File

@@ -34,8 +34,11 @@
</script>
<script>
(function() {
var push = Array.prototype.push,
slice = Array.prototype.slice;
var arrayProto = Array.prototype,
concat = arrayProto.concat,
pop = arrayProto.pop,
push = arrayProto.push,
slice = arrayProto.slice;
if (_.chain) {
return;
@@ -70,19 +73,19 @@
return this;
};
_.prototype.concat = _.wrap(_.prototype.concat, function(func) {
var result = func.apply(this, slice.call(arguments, 1));
_.prototype.concat = function() {
var result = concat.apply(this.__wrapped__, arguments);
if (this.__chain__) {
result = new _(result);
result.__chain__ = true;
}
return result;
});
};
_.prototype.pop = _.wrap(_.prototype.pop, function(func) {
func.apply(this, slice.call(arguments, 1));
_.prototype.pop = function() {
pop.apply(this.__wrapped__, arguments);
return this;
});
};
}());
</script>
<script src="../vendor/underscore/test/collections.js"></script>