Skip to content

Latest commit

 

History

History
384 lines (254 loc) · 5.58 KB

2019-01-20-ruby-vs-javascript.md

File metadata and controls

384 lines (254 loc) · 5.58 KB

Ruby vs Javascript comparison

| ruby | javascript | vs | comparison |

First of all it's not my writings and it's just a copy of Artem's Tyurin agentcooper/js-ruby-comparison repo

Note: This comparison uses pre-ES6 code snippets.


Arrays

Manipulation

Ruby

a = ["1", "2"]
a.push("3")

a.map!(&:to_i) # [1, 2, 3]

a.delete_at(1)
a # [1, 3]

a.reverse! # [3, 1]

a.unshift(777) # [777, 3, 1]

a.last # [1]

JavaScript

var a = ["1", "2"];
a.push("3");

a = a.map(function(n) { return parseInt(n, 10); });

a.splice(1, 1 /* how much */);
a; // [1, 3]

a.reverse() // [3, 1]

a.unshift(777); // 3
a; // [777, 3, 1]

/* or in place: */ var b = [3, 1];
                   [777].concat(b); // [777, 3, 1]
a.slice(-1)[0]; // 1
/* or */ a[a.length - 1]; // 1

Predicates

Ruby

a = [1, 2, 3]

a.index(2) # 1

a.all?{|n| n > 4} # false
a.any?{|n| n > 2} # true

a.keep_if{|n| n > 1} # [2, 3]

JavaScript

var a = [1, 2, 3];

a.indexOf(2); // 1

a.every(function(n) { return n > 4; }); // false
a.some(function(n) { return n > 2; });  // true

a.filter(function(n) { return n > 1;}); // [2, 3]

Array map methong

Ruby

a = ["aaa  ", "  bbb", "  ccc  "]

a.map(&:strip) # ["aaa", "bbb", "ccc"]

JavaScript

var a = ["aaa  ", "  bbb", "  ccc  "]

a.map(function(x) { return x.trim(); });               // ['aaa', 'bbb', 'ccc']
a.map(Function.prototype.call, String.prototype.trim); // ['aaa', 'bbb', 'ccc']
a.map(x => x.trim());                                  // ['aaa', 'bbb', 'ccc']

Slices

Ruby

a = [1, 2, 3, 4, 5]

a.slice(1..-2)  # [2, 3, 4]
a[1..-2]        # [2, 3, 4]

JavaScript

var a = [1, 2, 3, 4, 5];

a.slice(1, -1); // [2, 3, 4]

Iterating elements

a = [1, 2, 3]

a.each {|n| puts n}

a.each do |n|
    puts n
end


for i in 0..(a.length - 1) do
  puts a[i]
end

JavaScript

var a = [1, 2, 3];

a.forEach(function(n) { console.log(n); })

for (var i = 0; i < a.length; i++) {
  console.log(a[i]);
}

for (elem of a) {
  console.log(elem);
}

Strings

Ruby

'hello'.index('e')    # 1
'hello'.rindex('l')   # 3

if 'hello'.include? 'lo' then puts 'found' end

'hello' * 3           # 'hellohellohello'

'a/b/c'.split('/')    # ['a', 'b', 'c']

JavaScript

'hello'.indexOf('e')             // 1
'hello'.lastIndexOf('l')         // 3

if (~'hello'.indexOf('lo')) { console.log('found'); }

(new Array(3 + 1)).join('hello') // 'hellohellohello'

'a/b/c'.split('/')               // ['a', 'b', 'c']

Hash

Ruby

h = {}
h['a'] = 1
h['b'] = 2

h.each {|key, value| puts "#{key} #{value}" }

h.keys # ['a', 'b']
h.has_key?('c') # false

h.length # 2

h.delete("b")

JavaScript

var h = {};
h['a'] = 1;
h['b'] = 2;

for (key in h) { console.log(key, h[key]); }

Object.keys(h); // ['a', 'b']
h.hasOwnProperty('c') // false

Object.keys(h).length // 2

delete h.b

Functions

Basic usage

Ruby

def plus_5(num = 0) num + 5 end

plus_5     # 5
plus_5(10) # 15

[5, 10, 15].map { |k| plus_5(k) } # [10, 15, 20]

JavaScript

function plus_5(num) { return (num || 0) + 5; }

plus_5();   // 5
plus_5(10); // 15

[5, 10, 15].map(plus_5); // [10, 15, 20]

Multiple arguments

Ruby

def f(*args)
  puts args
end

JavaScript

function f() {
  var args = Array.prototype.slice.call(arguments);
  console.log(args);
}

Definition and invocation order

Ruby

sample_func

def sample_func
  puts "Hello World"
end

# => NameError: undefined local
# variable or method `sample_func'

JavaScript

sample_func();

function sample_func() {
  console.log("Hello World");
};

// => Hello World

Classes

Ruby

class Person
  attr_accessor :firstName, :lastName

  def initialize(firstName, lastName)
    @firstName = firstName
    @lastName = lastName
  end

  def fullName
    @firstName + " " + @lastName
  end
end

john = Person.new("John", "Malkovic")
john.fullName # "John Malkovic"

JavaScript

I'm lazy to write this example in ES6

function Person(firstName, lastName) {
  this.firstName = firstName;
  this.lastName = lastName;
}

Person.prototype.fullName = function() {
  return this.firstName + " " + this.lastName;
}

var john = new Person("John", "Malkovic");
john.fullName(); // "John Malkovic"

Math

Ruby

[-5, -1, -8].max            # -1

[-5, 15, 20].reduce(0, &:+) # 30

JavaScript

Math.max.apply(null, [-5, -1, -8]) // -1

[-5, 15, 20].reduce(function(sum, value) { return sum + value; }, 0) // 30
[-5, 15, 20].reduce((sum, value) => sum + value, 0) // 30

Other

Ruby

prng = Random.new()
prng.rand(5..9) # one of [5, 6, 7, 8, 9]

a, b = b, a # switch a and b

JavaScript

function rand(a, b) { return Math.floor(Math.random() * (b - a + 1) + a); }
rand(5, 9); // one of [5, 6, 7, 8, 9]

a = [b, b = a][0] // do not try at home :-)