cocosCreator中Protobuf的简单使用

proto文件格式:

protoc 数据iOS解析 protoc js_json

pro1.jpeg

准备工具:

cocosCreator

webStorm或者VSCode

安装node.js

下载protobufjs6.8.6

步骤:

安装protobufjs到全局

npm install -g protobufjs

使用npm install -g

参数将模块安装到全局,目的主要是方便使用protobufjs提供的pbjs命令行工具。pbjs可以将proto原文件转换成json、js等,以提供不同的加载proto的方式,我们可以根据自己的实际情况选择使用,还有pbts,用来将转化后的js文件转为ts

找到下载的protobuf.js

文件在\nodejs\node_modules\protobufjs\dist中

protoc 数据iOS解析 protoc js_protoc 数据iOS解析_02

image.png

把这个文件拖到Creator工程中并且导入为插件

protoc 数据iOS解析 protoc js_新功能_03

pro4.jpeg

在保存proto文件的目录下打开命令行执行如下命令

protoc 数据iOS解析 protoc js_protoc 数据iOS解析_04

pro5.jpeg

pbjs -t static-module -w commonjs -o proto.js *.proto

这句代码可以将文件中所有的.proto文件转化为一个proto.js文件

然后把proto.js文件放入代码目录中

protoc 数据iOS解析 protoc js_protobufjs 命令执行_05

pro6.jpeg

修改proto.js中protobuf的引用:

protoc 数据iOS解析 protoc js_protoc 数据iOS解析_06

pro7.jpeg

因为protobuf已经被设置为插件了

如果想使用TS格式可以通过protobufjs6新功能来实现

执行如下命令:

pbts -o proto.d.ts proto.js

注意:这里proto.d.ts一定要有.d

现在代码目录结构的样式就是这样的

protoc 数据iOS解析 protoc js_protobufjs 命令执行_07

pro8.jpeg

测试使用:

protoc 数据iOS解析 protoc js_json_08

pro9.jpeg

protoc 数据iOS解析 protoc js_新功能_09

pro10.jpeg

protoc 数据iOS解析 protoc js_命令行_10

pro11.jpeg

protoc 数据iOS解析 protoc js_新功能_11

pro12.jpeg

经过测试在手机上也是可以正常运行的

第二种方式:

由于现在工程中使用的TS,为了有更好的效果,所以还有另一种方式来依赖protobufjs6

1.安装protobufjs到全局

npm install -g protobufjs

使用npm install -g

参数将模块安装到全局,目的主要是方便使用protobufjs提供的pbjs命令行工具。pbjs可以将proto原文件转换成json、js等,以提供不同的加载proto的方式,我们可以根据自己的实际情况选择使用,还有pbts,用来将转化后的js文件转为ts

打开工程目录执行命令行:

npm init

执行后一路回车会在工程目录下生成package.json

在工程目录中执行命令行:

npm install protobufjs

会生成protobufjs的依赖库

protoc 数据iOS解析 protoc js_json_12

pro13.jpeg

4.在保存proto文件的目录下打开命令行执行如下命令

pbjs -t static-module -w commonjs -o proto.js *.proto

protoc 数据iOS解析 protoc js_新功能_13

pro14.jpeg

这句代码可以将文件中所有的.proto文件转化为一个proto.js文件

protoc 数据iOS解析 protoc js_新功能_14

pro15.jpeg

这个不用修改proto文件

6.如果想使用TS格式可以通过protobufjs6新功能来实现

执行如下命令:

pbts -o proto.d.ts proto.js

注意:这里proto.d.ts一定要有.d

现在代码目录结构的样式就是这样的

protoc 数据iOS解析 protoc js_protobufjs 命令执行_15

pro16.jpeg

然后就可以使用了,而且代码提示很友好~

protoc 数据iOS解析 protoc js_protobufjs 命令执行_16

pro17.jpeg

protoc 数据iOS解析 protoc js_protobufjs 命令执行_17

pro18.jpeg