基于星云链的智能合约与Dapp(九)——Dapp开发

安装neb.js

neb.js提供javascript开发的API接口

1.创建一个neb文件夹,在终端命令行中进入该文件夹,克隆neb.js

git clone https://github.com/nebulasio/neb.js.git

2.会新建一个neb.js文件夹,进入该文件夹,安装所有依赖

npm install

3.安装gulp

npm install gulp

4.打包生成neb.js等文件

gulp

5.执行成功会生成/dist文件夹,文件夹中会生成我们要使用js文件。

  • neb.js:Used in browser side. Including outside dependency.
  • neb-light.js:Used in Repl console. Not including outside dependency.
  • nebulas.js: Fully functional in the browser. Users can create an address, sign a transaction, and deploy/call a smart contract.
安装nebPay

NebPay SDK 为不同平台的交易提供了统一的支付接口,开发者在Dapp页面中使用NebPay API可以通过浏览器插件钱包、手机app钱包等实现交易支付和合约调用。
github地址:https://github.com/nebulasio/nebPay
安装方法同上,会生成nebPay.js文件

Dapp开发

将生产的nebulas.js和nebPay.js放在libs文件夹下,例如下图:


course.js源码如下:

'use strict';

var courseContract = function () {
    LocalContractStorage.defineProperty(this, "size");
}

courseContract.prototype = {
    init: function () {
        this.size = 0;
    },

    save: function (value) {
        this.size = value;
    },

    read: function () {
        return this.size;
    }
};

module.exports = courseContract;

course.html源码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Course</title>
    <script src="libs/jquery-3.3.1.min.js"></script>
    <script src="libs/nebPay.js"></script>
    <script src="libs/nebulas.js"></script>
    <link rel="stylesheet" href="css/bootstrap.min.css">
</head>
<body>
<input type="text" class="form-control" style="margin-top: 20px; height: 40px;"
       id="line1">
<button type="button" style="margin-top: 10px;" class="btn btn-primary btn-lg btn-block" id="save">保存</button>
<button type="button" style="margin-top: 10px;" class="btn btn-primary btn-lg btn-block" id="read">读取</button>
<div id="value" style="font-size: 20px; color: red"></div>

<script>
    var dappAddress = "n1uSBFi4JnGtUNu8mGKmdF5orMg8b7GnN7w";
    var NebPay = require("nebpay");
    var nebPay = new NebPay();


    $("#save").click(function () {
        var str = $("#line1").val().trim();
        var callArgs = "[\"" + str + "\"]";
        nebPay.call(dappAddress, "0", "save", callArgs, {
            listener: function (resp) {

            }
        });
    });


    $("#read").click(function () {
        var callArgs = "[]";
        nebPay.simulateCall(dappAddress, "0", "read", callArgs, {
            listener: function (resp) {
                $("#value").html(resp.result);
            }
        });
    });
</script>
</body>
</html>

上面的源码使用了nebPay的方式调用智能合约中的方法,我们还可以使用nebulasapi.call的方式调用智能合约中的方法,例如:

<script>
    var dappAddress = "n1uSBFi4JnGtUNu8mGKmdF5orMg8b7GnN7w";
    var NebPay = require("nebpay");
    var nebPay = new NebPay();


    // 直接访问星云链的api
    var nebulas = require("nebulas"), Account = nebulas.Account, neb = new nebulas.Neb();
    // 设置使用的网络
    neb.setRequest(new nebulas.HttpRequest("https://testnet.nebulas.io"));

    $("#save").click(function () {
        var str = $("#line1").val().trim();
        var callArgs = "[\"" + str + "\"]";
        nebPay.call(dappAddress, "0", "save", callArgs, {
            listener: function (resp) {

            }
        });
    });


    /*   $("#read").click(function () {
     var callArgs = "[]";
     nebPay.simulateCall(dappAddress, "0", "read", callArgs, {
     listener: function (resp) {
     $("#value").html(resp.result);
     }
     });
     });
     */

    $("#read").click(function () {
        var from = Account.NewAccount().getAddressString();
        var value = "0";   // 金额
        var nonce = "1";   // 交易序号
        var gas_price = "1000000" // 手续费价格
        var gas_limit = "2000000" // 手续费限制
        var callFunction = "read";
        var callArgs = "[]"; //in the form of ["args"]
        var contract = { // 合约
            "function": callFunction,  // 方法名
            "args": callArgs            // 参数
        }

        // 使用api.call执行合约中的方法
        neb.api.call(from, dappAddress, value, nonce, gas_price, gas_limit, contract).then(function (resp) {
            $("#value").html(resp.result);
        }).catch(function (err) {
            $("#value").html("error:" + err.message);
        })
    });
</script>
运行Dapp

第一步



第二步



第三步

第四步



到此为止,一个基于星云链的Dapp就开发完成了,不要吐槽举例的Dapp太简单了,重在演示过程。
下一章
内置库调用
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容