Slide 1

Slide 1 text

Live Script 10 Feb, 2016 / Meguro.es #2 Pine Mizune

Slide 2

Slide 2 text

⾃⼰紹介 o ID / HN: @pine613 o 好きな言語: JavaScript / Crystal o 仕事で書いてる: Perl / Swift / Kotlin o Mobile Factory, Inc o 最寄り: 五反田駅 o 本日は @mizuki_r 氏の代打です ⽬⿊のとなり

Slide 3

Slide 3 text

⽬次 1. LiveScript とは何か 2. 別に Babel でよくない ? 3. LiveScript の特筆すべき⽂法 – 関数型記法・ほか 4. まとめ

Slide 4

Slide 4 text

LiveScript とは何か ? • CoffeeScript から派生した AltJS • 関数型言語として進化 • 利用人口が少ない

Slide 5

Slide 5 text

別に Babel で良くない ? • ⾃分もそう思います! • 本筋の開発で使うことは意図してません • このプレゼンで意図した使い⽅ – ⼩さなモジュール – gulpfile / webpack.config

Slide 6

Slide 6 text

インストール⽅法 repl があるのでぜひ弄ってみてください! $ npm i -g livescript ※ repl: 対話型インタプリタ

Slide 7

Slide 7 text

LiveScript の⽂法 1. 基本⽂法 2. パイピング 3. 関数 4. カリー化・関数合成

Slide 8

Slide 8 text

基本⽂法 (1/2) if 2 + 2 == 4 'somethingʼ else ʻsomething elseʼ 基本は CoffeeScript と同じ if (2 + 2 == 4) { 'somethingʼ; } else { ʻsomething elseʼ; } LiveScript JavaScript

Slide 9

Slide 9 text

基本⽂法 (2/2) require! { lodash: _ gulp } require が圧倒的に楽 const _ = require(ʻlodashʼ) const gulp = require(ʻgulpʼ) LiveScript JavaScript

Slide 10

Slide 10 text

パイピング x = [1 2 3] |> reverse |> head メソッドのネスト呼び出しの糖衣構文 let x = head(reverse([1, 2, 3])) LiveScript JavaScript

Slide 11

Slide 11 text

関数 (1/2) f = (x) -> x * x f(10) #=> 100 CoffeeScript と同様に定義可能 const f = (x) => x * x f(10) #=> 100 LiveScript JavaScript

Slide 12

Slide 12 text

関数 (2/2) fold (+) [ 1 to 10 ] #=> 55 演算子は関数として扱える fold( (a, b) => a + b, [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ] ) LiveScript JavaScript

Slide 13

Slide 13 text

カリー化 f = (* 2) f(8) # => 16 f = (a, b) --> a + b g = f(2) g(8) #=> 16 部分的に引数を固定した関数を得る LiveScript

Slide 14

Slide 14 text

関数合成 f = (x) => x + 2 g = (x) => x * 10 (f >> g) 3 #=> 50 LiveScript 2つの関数を合成して関数を生成 let f = (x) => x + 2 let g = (x) => x * 10 g(f(3)) #=> 50 JavaScript

Slide 15

Slide 15 text

まとめ • LiveScript は CoffeeScript 派生言語 • 関数型方面へ進化 • ES2015 に飽きた時の暇つぶしにどうぞ

Slide 16

Slide 16 text

【宣伝】Gotanda.js #3 開催します n Gotanda.js #3 in freee ü 日時: 2016 年 3 月 11 日 (金) ü 会場: freee 株式会社 ü 内容: LT x 8 (5min LT x 8) ü 申し込みは Connpass から! http://gotandajs.connpass.com/event/26027/

Slide 17

Slide 17 text

fin.