造了一堆的轮子

2015-11-19 12:35:08 +08:00
 bramblex

看完了计算的本质,准备把所有代码用 JS 实现一边。而且保证尽量和书上的 Ruby 代码长得一样……于是就不得不造了一堆轮子……
https://github.com/bramblex/simple/tree/master/src

看看都有什么……
Utils:
.indent(n, block [, indent_char]) 用来一个整个字符串块进行缩进的
.indent.skipFirstLine() 跳过第一行,然后缩进后面的行
.attrs(obj) 遍历一个 object ,并且将他的属性名,并且根据 self 和 proto 分类。
.slice(obj) 将一个对象切片成 [key, value] 的数组。
.sliceStr(string) 将一个字符串切成字符数组
.render(template_string, obj) 模板字符串。示例 render('My name is <%name%>!', {name: 'Tom'}) => 'My name is Tom!'
.inspect(something) 和 node 里面的 util.inspect 类似……这里我写出来只是为了不依赖 node 。
.color(c, str) 把一个字符串加上颜色(只在终端里有效)
.surround(pair, string) 给字符串加上括号之类的。
.merge(target, obj) 将两个对象混合,并返回一个新对象。
.kv(key, value) 返回一个只带有此键值对的对象。
.importScope(scope_name) 生成一段代码,把某个对象的所有属性导入当前作用域。和 eval 一起用
.equal(a, b) 比较 a 和 b 是否相同。如果 a, b 中带有 equal 方法则用 a 的 equal 比较 b 。会递归比较数组。

Struct 类……和 Ruby 的 Struct 类一样
比如 Ruby 中的

class A < Struct.new(:a, :b)
a = A.new(1, 2)
b = A.new(1, 2)
puts a # => #<Struct A a=1, b=2>
a == b #=> true

可以这样写

var A = Struct('A', ['a', 'b'])
var B = Struct('B', {a:0, b:0})
var a = A(1, 2)
var b = A(1, 2)
var c = B()
console.log(a) // => #<Struct a=1, b=2>
console.log(c) // => #<Struct a=0, b=0>
a.equal(b) // => true
A([1,2], [1,2]).equal([1,2], [1,2]) // => true
A(A(1,2), A(1,2)).equal(A(A(1,2), A(1,2))) // => true

Set 类, 和 Ruby 中的 Set 类类似。
别问我为什么不用 ES6 的 Set , Set([1,2,3]) === Set([1,2,3]) 返回 false ,这让我怎么玩……
我的现在可以这样玩……

Set([1,2,3]).equal(Set([3,2,1])) // => true
Set([1,2,3]).equal(Set([3,2,1,3,2,1])) // => true
Set([A(1,2)]).equal(Set([A(1,2)])) // => true

反正是玩具,不追求效率,有功能就够了。

3137 次点击
所在节点    JavaScript
9 条回复
wittyfox
2015-11-19 12:48:08 +08:00
jj 又造轮子
jings
2015-11-19 16:11:10 +08:00
jj 又造轮子
jings
2015-11-19 16:12:32 +08:00
暖贴
bramblex
2015-11-19 18:17:06 +08:00
@wittyfox ╮(╯_╰)╭

反正,我就是喜欢造轮子
fyyz
2015-11-19 18:28:09 +08:00
知乎有个轮子哥,这里有个小轮子哥(^3^)
bramblex
2015-11-19 18:31:00 +08:00
@fyyz

╮(╯_╰)╭……
轮子哥是我我们直系师兄唉……
fyyz
2015-11-19 18:36:53 +08:00
小荆棘准备自己开发一套语言出来吗
bramblex
2015-11-19 18:51:20 +08:00
@fyyz

嗯,作为玩具。
linux40
2015-11-19 22:31:09 +08:00
target 到 js...

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/237270

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX