-
Notifications
You must be signed in to change notification settings - Fork 2
/
coffeescript.html
181 lines (126 loc) · 4.95 KB
/
coffeescript.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8' />
<meta http-equiv="X-UA-Compatible" content="chrome=1" />
<meta name="description" content="Akkunchoi.github.com : " />
<link rel="stylesheet" type="text/css" media="screen" href="/stylesheets/rainbow-github.css">
<link rel="stylesheet" type="text/css" media="screen" href="/stylesheets/stylesheet.css">
<title>Coffeescript | akkunchoi@github</title>
<link rel="alternate" type="application/rss+xml" title="RSS Feed for mysite.com" href="/feed.xml" />
<script type="text/javascript" src="/javascripts/rainbow-custom.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function($){
//$('pre > code').highlight({source: 1, zebra: 1, indent: 'space', list: 'ol'});
});
</script>
</head>
<body>
<!-- HEADER -->
<div id="header_wrap" class="outer">
<header class="inner">
<a id="forkme_banner" href="https://github.com/akkunchoi">View on GitHub</a>
<h1 id="project_title">
<a href="/">akkunchoi.github.com</a>
</h1>
<h2 id="project_tagline"></h2>
</header>
</div>
<!-- MAIN CONTENT -->
<div id="main_content_wrap" class="outer">
<section id="main_content" class="inner">
<article class="posts">
<header>
<h1>Coffeescript</h1>
<ul class="tags">
<li class="inline archive_list"><a class="tag_list_link" href="/tag/coffeescript">coffeescript</a></li>
<li class="inline archive_list"><a class="tag_list_link" href="/tag/javascript">javascript</a></li>
</ul>
</header>
<div class="posts-content">
<p>JavaScripter が <a href="http://coffeescript.org/">CoffeeScript</a> に移行する際の要点をまとめ。</p>
<h2 id="section">関数定義は -></h2>
<p><code>function</code> と <code>{</code> と <code>}</code> は消します。代わりに <code>-></code> を入れます。</p>
<pre><code data-language="javascript"> // javascript
var square;
square = function(x) {
return x * x;
};
</code></pre>
<pre><code data-language="coffeescript"> # coffeescript
square = (x) -> x * x
</code></pre>
<p>タイプ数減りますね。</p>
<h2 id="section-1">クラス定義</h2>
<pre><code data-language="javascript"> // javascript
var Animal;
Animal = (function() {
function Animal(name) {
this.name = name;
}
Animal.prototype.move = function(meters) {
return alert(this.name + (" moved " + meters + "m."));
};
return Animal;
})();
</code></pre>
<pre><code data-language="coffeescript"> # coffeescript
class Animal
constructor: (@name) ->
move: (meters) ->
alert @name + " moved #{meters}m."
</code></pre>
<p>クラスの定義方法を統一させることができるのは良いかも。</p>
<p><code>@name</code> は ruby の インスタンス変数のような感じです。
しかし、<code>constructor: (@name) -></code> この一行で <code>this.name</code> にセットされるのはなんだかキモいです。</p>
<p>継承もできます。</p>
<h2 id="this-">thisの束縛は =></h2>
<pre><code data-language="javascript"> // javascript
var _this = this;
$.each([1, 2, 3, 4, 5], function(k, v) {
_this.moge(v);
});
</code></pre>
<pre><code data-language="coffeescript"> # coffeescript
$.each [1,2,3,4,5], (k,v) =>
this.moge(v)
</code></pre>
<p>もう <code>var self = this;</code> なんて書かなくて良い!</p>
<h2 id="section-2">関数呼び出しは、引数がある場合は()を省略可能</h2>
<p>Rubyのノリです。</p>
<p>ただし、引数がない関数の場合は <code>()</code> が必要(プロパティ呼び出しと区別がつかないからだろう)。</p>
<h2 id="return">最後の式はreturnする</h2>
<p>Rubyのノリです。</p>
<h2 id="section-3">インデント重要</h2>
<p>Pythonのノリです。</p>
<h2 id="section-4">その他</h2>
<ul>
<li>セミコロンは不要。あってもエラーにはならない</li>
</ul>
</div>
<footer>
<p>Last updated at <time>2012-12-07 20:28:13 +0900</time></p>
<!-- <p>Published at <time>2012-11-13</time></p> -->
</footer>
</article>
</section>
</div>
<!-- FOOTER -->
<div id="footer_wrap" class="outer">
<footer class="inner">
<p>Published with <a href="http://pages.github.com">GitHub Pages</a></p>
</footer>
</div>
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-36469923-5']);
_gaq.push(['_trackPageview']);
(function() {
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
})();
</script>
</body>
</html>