1、安装node-gyp
npm install node-gyp -g
2、创建binding.gyp
{
"targets": [
{
"target_name": "hello",
"sources": [ "hello.cc" ],
"include_dirs": [
"<!(node -e \"require('nan')\")"
]
}
]
}
3、创建hello.cc
#include <nan.h>
void Method(const Nan::FunctionCallbackInfo<v8::Value>& info) {
v8::Local<v8::Function> cb = info[0].As<v8::Function>();
const unsigned argc =1;
v8::Local argv[argc] = {Nan::New("hello world").ToLocalChecked() };
Nan::Call(cb, info.Holder(), argc, argv);
}
voidInit(v8::Local exports) {
exports->Set(Nan::New("hello").ToLocalChecked(),
Nan::New(Method)->GetFunction());
}
NODE_MODULE(hello, Init)
4、创建hello.js
const addon = require('bindings')('hello');
addon.hello(function (res) {
console.log(res);
})
5、创建 xcode 工程
1、npm init
2、npm install bindings nan -s
3、node-gyp configure
4、node-gyp build
5、node-gyp configure -- -f Xcode
6、配置xcode scheme
1、选择scheme
data:image/s3,"s3://crabby-images/66307/663072552deee0a5a2548a24ec536fbf7a862586" alt=""
2、编辑info, 点击executable 选择other,弹出对话框选择node
data:image/s3,"s3://crabby-images/2ae2d/2ae2dc11f14d5dcd52bf027531fca69778d0e4c4" alt=""
data:image/s3,"s3://crabby-images/3ed2a/3ed2aa8856dd12245ab2ca2b4e08bae49847d268" alt=""
3、编辑arguments, 点➕ 输入刚创建的hello.js 目录
data:image/s3,"s3://crabby-images/ac026/ac0269fa47e719da46e821d99e80b348f27b7e8e" alt=""
7、执行
data:image/s3,"s3://crabby-images/da0ca/da0ca36a496a3e8afc3a2542fe62f628d22cc0a4" alt=""
8、断点调试
data:image/s3,"s3://crabby-images/1d3a4/1d3a4547f51e07bbe577b8c8d159e26e7a4d075a" alt=""
9、js调试
1、修改arguemts
data:image/s3,"s3://crabby-images/39acd/39acd28af9d871c1a1a29c394601963016d79fe8" alt=""
2、chrome 内调试js
网友评论