Browser-Solidity的本地安装及使用介绍
正所谓工欲善其事必先利其器,巧妇也难为无米之炊,所以在学习智能合约之前,必须要先把工具准备好。Browser-Solidity 是 Ethereum 官方的一个IDE项目,该名称准确的表述了,它是一款基于浏览器的 Solidity 集成开发环境,官方正式名称称之为 Remix,通过它我们可以编辑、编译、发布我们自己的智能合约。
基于浏览器的开发环境,那么它有在线版吗?有,就是这里https://remix.ethereum.org。既然有在线版为什么还要安装呢?你亲身访问一下就能发现答案了。
环境准备
我们以 Mac 为开发平台,且 Mac上已经装好了 npm 和 Node.js,如果你的 Mac 上没有安装,那么你可以参考这里的教程:How to Install npm & Manage npm Versions
2017年2月8日补充:今天手贱更新了一下Browser-solidity,重新执行npm install
,然后 solc 这个包总是安装不成功,直到 brew install wget
。🤷♀️
安装&
通过npm直接安装
以太坊真是日新月异,如新生儿般一天一个样。废话不多说,Remix已正式更名为Remix-ide,官方也已将其发布为npm包,可以通过npm直接安装,方便了很多:
1 | npm install remix-ide -g |
启动Remix-ide,安装成功后,直接在命令行键入如下命令启动。
1 | remix-ide |
然后打开 Chrome,或 Safari,在地址中输入:localhost:8080即可。
下面的clone安装方法已不在推荐,可以选择性阅读。
clone项目到本地安装
打开终端,进入你准备的好安装目录,将 browser-solidity 项目 clone 到本地。
1 | git clone https://github.com/ethereum/browser-solidity |
进入 browser-solidity 目录后,运行如下命令,开始安装。
1 | npm install |
安装完毕之后,输入如下命令,开启 Remix 本地服务。
1 | npm start |
成功启动后,终端会输出如下内容,主要是一些与启动、参数说明和警告等相关信息:
1 | > browser-solidity@0.0.0 start /Users/dracarys/Documents/Ethereum/browser-solidity |
这时打开浏览器,在地址栏中输入:http://127.0.0.1:8080 即可。
界面介绍
Remix 界面入下图所示:
如果您熟悉编程,接触过很多IDE,那么 Remix 的界面你一定也不陌生,所以你可以跳过该部分,对 Remix 的理解不会受到任何影响。
下面是对上图中五个功能区域的简单介绍:
- 红色 工具栏,这里可以进行新建文件、打开文件,发布到Github、向另一个实例拷贝和建立本地连接等操作;
- 橙色 文件导航区,在这里可以分常方便地在各个文件间进行切换;
- 黄色 代码编辑区,可以点击上方的+-对代码文字进行放大和缩小,还可以单击上方的《、》符号隐藏左右边栏;
- 绿色 信息输出区,这里可以看到代码的输出结果和编译信息,还可以通过该区域上方的下拉列表对信息进行过滤,和搜索;
- 紫色 属性编辑区,该区域有六个分页,分别是:Compile、Run、Setting、Analysis、Debug、Support。下面我们会着重介绍区域的设置。
功能介绍
前四个区域没什么好介绍的,大家只要上手简单操作一下就能明白。这里我们着重介绍下区域5,属性编辑区。这里我么只介绍Setting、Run、Compile、Debug 四个个分页,剩余两个分页功能非常直观,如果不是理解建议大家自行查询,不再赘述。
Setting IDE设置
Setting界面如下图所示:
Solidity version
设置 Solidity 的版本,这个的版本必须高于或者与你在源码中指定的版本相同,否则可能会导致一些无法预料的行为,非常关键。这里建议大家选择名字较短的稳定版,以减少不必要的麻烦。
General setting
通用设置,这里可以设置以及文本断行,是否默认启用JavaScript VM,以及是否启用优化;
Theme
主题设置,没什么好介绍的,只有2个主题,选择一个自己喜欢的即可。
Plugin
插件,目前还处于Alpha阶段,如果不了解,请不要更改。(我就是那个不了解的,还望各位大牛指点)
Run 运行设置
Run界面如下图所示:
红色区域
Environment
运行环境选择,默认为本地 JavaScript VM,Web3 Provider 用于连接指定的虚拟机服务,可以用来本地测试或者小范围的局域网测试。还有一个 Injected Web3 功能暂时不明,望高人告知。Account
账户,默认的 JavaScript VM 提供了 5 个虚拟账户,每个账户有100 ether,如果连接到 Web3 Provider,那么这里会显示你在这台 Provider 上的账户。Gas limit
Gas上限,并不是越大越好,当然也不能太小,否则会影响交易。有关Gas的进一步信息,你可以访问这里Gas and etherValue
即Gas price,输入后不要忘记在右侧的下拉列表中设置价格单位。如果你不熟悉 Wei 和 Ether 之间的换算可以参见下表
单位 | 换算率 | Wei |
---|---|---|
wei | 1 | 1 |
Kwei (babbage) | 1e3 wei | 1,000 |
Mwei (lovelace) | 1e6 wei | 1,000,000 |
Gwei (shannon) | 1e9 wei | 1,000,000,000 |
microether (szabo) | 1e12 wei | 1,000,000,000,000 |
milliether (finney) | 1e15 wei | 1,000,000,000,000,000 |
ether | 1e18 wei | 1,000,000,000,000,000,000 |
橙色区域
选择合约
如果你有多个合约,那么可以在这里选择运行那个合约Create
有些合约有初始值,那么可以在这里设置,然后在点击 Create 按钮,成功后才会出现绿色区域。At Address
从指定的地址加载一个已经存在的合约,加载成功后会出现在绿色区域内
黄色区域
暂时不明,待补充。
绿色区域
只有成功运行才会显示该区域,在这里你可以对自己编写的合约各个方法进测试。例如上图,这里我只写了一个 pay 函数,那么就可以在这里输入数值,然后点击 pay 来查看输出结果,以便验证该函数是否运行正常。
Compile 编译设置
Compile 界面如下图所示:
`Start to compile` 点击该按钮即开始编译,这里我们勾选 auto compile,这样就不用我们每次都点了,而且还能及时帮我们发现语法上的错误。
选择合约
可以在多个合约间进行切换,注意,这里只有编译才能显示,如果未编译,这里将为空。Detail
点击可以查看上一步已选择合约的详细信息(如下图)
Publish on Swarm
发布到 Swarm?还不是很理解,猜测:跟选择的运行环境有关,发不到官方的测试链或者正式链?望大牛提点。
Debug
Debug 界面如下图所示:
最后
IDE的某些功能会随着使用逐渐加深了解,所以请不要在IDE的熟悉上花费太多时间,能上手操作即可,就像小时候我们学说话一样,相信你我都绝不是在能说绕口令之后才叫爸爸妈妈的。
未完待续!