推荐前端网址:http://keenwon.com/html
在Javascript里比较常见的数据格式就是json,xml,可是这两种格式在数据传输方面有明显不足。而Protocol Buffers能够很好的解决这个问题,下面引用百科的对Protocol Buffers的定义:前端
Protocol Buffers是Google公司开发的一种数据描述语言,相似于XML可以将结构化数据序列化,可用于数据存储、通讯协议等方面。它不依赖于语言和平台而且可扩展性极强。现阶段官方支持C++、JAVA、Python等三种编程语言,但能够找到大量的几乎涵盖全部语言的第三方拓展包。node
同为数据的存储格式,和json相比,Protocol Buffers的优势主要体如今性能和体积上,性能方面须要实际的测试,暂且不说,数据体积方面的优点是比较明显的,例如,一个json文件:c++
再看一个protobuf文件:git
json文件的问题在于无效数据太多,例如Name
和Gender
等,这些内容大量重复出现,使得数据体积较大。再看protobuf文件,它使用一个惟一的id(数字)来代替json里复杂的key,这样只要数据发送方和接受方都按同一套“模板”解析数据,就能够大大缩短报文体积。github
ProtoBuf.js是基于ByteBuffer.js的Protocol Buffers纯Javascript实现。主要功能是解析.proto
文件,构建message类,和简单的编码、解码。目前我在一个node-webkit中使用protobuf格式于服务端进行数据交互(服务端是按照旧c++客户端要求实现的protobuf)。web
目前对ProtoBuf.js的使用主要就是读取旧的.proto
文件,建立message类,编码,发送给服务端,以下:编程
user.proto
文件:json
nodejs代码:编程语言
解码的方法也很简单:
另外protobuf.js还提供了一些工具,例如.proto
和.json
的转换等,具体参看他的官网:https://github.com/dcodeIO/ProtoBuf.js
- 完 -