Sha256: e641802bac11fdca881d7191faf35ed7a702e408af5e42582fe46cc4e6563c0b
Contents?: true
Size: 1.69 KB
Versions: 28
Compression:
Stored size: 1.69 KB
Contents
$(document).ready(function() { module("Chaining"); test("map/flatten/reduce", function() { var lyrics = [ "I'm a lumberjack and I'm okay", "I sleep all night and I work all day", "He's a lumberjack and he's okay", "He sleeps all night and he works all day" ]; var counts = _(lyrics).chain() .map(function(line) { return line.split(''); }) .flatten() .reduce(function(hash, l) { hash[l] = hash[l] || 0; hash[l]++; return hash; }, {}).value(); ok(counts['a'] == 16 && counts['e'] == 10, 'counted all the letters in the song'); }); test("select/reject/sortBy", function() { var numbers = [1,2,3,4,5,6,7,8,9,10]; numbers = _(numbers).chain().select(function(n) { return n % 2 == 0; }).reject(function(n) { return n % 4 == 0; }).sortBy(function(n) { return -n; }).value(); equal(numbers.join(', '), "10, 6, 2", "filtered and reversed the numbers"); }); test("select/reject/sortBy in functional style", function() { var numbers = [1,2,3,4,5,6,7,8,9,10]; numbers = _.chain(numbers).select(function(n) { return n % 2 == 0; }).reject(function(n) { return n % 4 == 0; }).sortBy(function(n) { return -n; }).value(); equal(numbers.join(', '), "10, 6, 2", "filtered and reversed the numbers"); }); test("reverse/concat/unshift/pop/map", function() { var numbers = [1,2,3,4,5]; numbers = _(numbers).chain() .reverse() .concat([5, 5, 5]) .unshift(17) .pop() .map(function(n){ return n * 2; }) .value(); equal(numbers.join(', '), "34, 10, 8, 6, 4, 2, 10, 10", 'can chain together array functions.'); }); });
Version data entries
28 entries across 26 versions & 5 rubygems