用于使用EOSIO RPC API与基于EOSIO的区块链集成的Javascript API。html
npm install eosjs@beta or yarn add eosjs@beta
在本地克隆此存储库而后运行npm run build-web
或yarn build-web
,浏览器发行包将位于dist-web
中,能够直接复制到项目存储库中。dist-web
文件夹包含准备生产的缩小捆绑包以及用于调试的库的源映射版本,有关完整的浏览器用法示例,请参阅文档。node
若是你有一个转换器,则支持在浏览器中使用ES6模块语法导入,就像Babel:web
import { Api, JsonRpc, RpcError } from 'eosjs'; import JsSignatureProvider from 'eosjs/dist/eosjs-jssig'; // development only
NodeJS支持使用commonJS语法导入。npm
const { Api, JsonRpc, RpcError } = require('eosjs'); const JsSignatureProvider = require('eosjs/dist/eosjs-jssig'); // development only const fetch = require('node-fetch'); // node only; not needed in browsers const { TextEncoder, TextDecoder } = require('util'); // node only; native TextEncoder/Decoder const { TextEncoder, TextDecoder } = require('text-encoding'); // React Native, IE11, and Edge Browsers only
签名提供程序持有私钥并负责签名交易。json
在浏览器中使用JsSignatureProvider并不安全,只能用于开发目的,在网页上下文以外使用安全保管库,以确保在生产中签名交易时的安全性。segmentfault
const defaultPrivateKey = "5JtUScZK2XEp3g9gh7F8bwtPTRAkASmNrrftmx4AxDKD5K4zDnr"; // useraaaaaaaa const signatureProvider = new JsSignatureProvider.default([defaultPrivateKey]);
打开与JSON-RPC的链接,包括在NodeJS上的fetch
。api
const rpc = new JsonRpc('http://127.0.0.1:8888', { fetch });
在浏览器中使用时包含textDecoder
和textEncoder
。浏览器
const api = new Api({ rpc, signatureProvider, textDecoder: new TextDecoder(), textEncoder: new TextEncoder() });
transact()
用于使用可选的配置对象参数将交易签名并推送到区块链,此参数能够重写broadcast: true
的默认值,并可用于填充给定blocksBehind
和expireSeconds
的TAPOS字段。若是没有配置选项,则预计将使用TAPOS字段(expiration
、ref_block_num
、ref_block_prefix
)解压缩交易,并自动将其广播到链上。安全
(async () => { const result = await api.transact({ actions: [{ account: 'eosio.token', name: 'transfer', authorization: [{ actor: 'useraaaaaaaa', permission: 'active', }], data: { from: 'useraaaaaaaa', to: 'useraaaaaaab', quantity: '0.0001 SYS', memo: '', }, }] }, { blocksBehind: 3, expireSeconds: 30, }); console.dir(result); })();
使用RpcError
处理RPC错误。async
... try { const result = await api.transact({ ... } catch (e) { console.log('\nCaught exception: ' + e); if (e instanceof RpcError) console.log(JSON.stringify(e.json, null, 2)); } ...
npm run test or yarn test
运行npm run build-web
构建浏览器发行包,而后在你选择的浏览器中打开src/tests/web.html
,该文件应该运行6次测试,在每次测试后将结果传递到网页上,延迟时间为2秒,最后两个测试应该为无效的交易和无效的rpc调用将异常传递到网页上。