https://github.com/ethereumjs/browser-builds

ethereumjs - Browser Builds

This repository contains browser builds of the following ethereumjs libraries:

这个存储库包含以下ethereumjs库的浏览器构建(其实就是将下面的ethereumjs库构造成浏览器能够使用的js文件形式)

They are built using browserify with a known set of working dependencies.

使用带着具有一组已知的工作依赖项的browserify来构建

For every library/build collection there is a larger plain source version also including the source mappings (e.g. ethereumjs-vm-x.x.x.js) and a minified version for use in production (e.g. ethereumjs-vm-x.x.x.min.js).

这里对每个库/构建收集有一个更大的包含资源映射(比如ethereumjs-vm-x.x.x.js) 的纯资源版本,以及在生产时使用的简化版本 (比如ethereumjs-vm-x.x.x.min.js)

Note注意:

This repository was just lately (October 2017) revived. Currently all builds are considered experimental in terms of API stability, functionality and security!

这个存储库最近(2017/10)才恢复使用。目前,从API的稳定性、功能和安全性来看,所有构建都是实验性的

Usage使用

In your web application, include only one of the builds from the dist directory. All exports will be available under the global ethereumjs.

在你的web应用中,只包含来自dist目录之一的构建。在全局变量ethereumjs下,所有的构建都是可用的

Note: all packages expect ECMAScript 6 (ES6) as a minimum environment. From browsers lacking ES6 support, please use a shim (like es6-shim) before including any of the builds from this repo.

注意:所有包都期待使用 ECMAScript 6 (ES6) 作为最小的环境。如果浏览器缺少ES6支持,从该存储库中包含任何构建之前,请使用shim(like es6-shim)

Examples例子

Examples for usage of the browser builds can be found in the examples directory:

vm.html

<!doctype html>

<html lang="en">
<head>
<meta charset="utf-8">
<title>EthereumJS VM - Browser Example</title>
</head> <body>
<script src="../dist/ethereumjs-vm/ethereumjs-vm-2.3.1.js"></script> <script>
var vm = new ethereumjs.VM() var code = '7f4e616d65526567000000000000000000000000000000000000000000000000003055307f4e616d6552656700000000000000000000000000000000000000000000000000557f436f6e666967000000000000000000000000000000000000000000000000000073661005d2720d855f1d9976f88bb10c1a3398c77f5573661005d2720d855f1d9976f88bb10c1a3398c77f7f436f6e6669670000000000000000000000000000000000000000000000000000553360455560df806100c56000396000f3007f726567697374657200000000000000000000000000000000000000000000000060003514156053576020355415603257005b335415603e5760003354555b6020353360006000a233602035556020353355005b60007f756e72656769737465720000000000000000000000000000000000000000000060003514156082575033545b1560995733335460006000a2600033545560003355005b60007f6b696c6c00000000000000000000000000000000000000000000000000000000600035141560cb575060455433145b1560d25733ff5b6000355460005260206000f3' console.log('Code to be run in the VM:')
console.log(code) vm.on('step', function (data) {
console.log(data.opcode.name)
}) vm.runCode({
code: ethereumjs.Buffer.Buffer.from(code, 'hex'),
gasLimit: ethereumjs.Buffer.Buffer.from('ffffffff', 'hex')
}, function (err, results) {
console.log('returned: ' + results.return.toString('hex'))
console.log('gasUsed: ' + results.gasUsed.toString())
console.log(err)
})
</script>
</body>
</html>

Start an http-server from the main directory of the repository to run the examples in the browser.

从存储库的主目录开启 http-server去在浏览器中运行该例子

Build构建

Builds are done using the .js exports compilation files from the src/ directory and using the build.js script from the main directory to create the build in the dist/ folder.

构建的完成需要先src/文件夹中使用.js输出编译文件,然后使用来自主目录的build.js脚本在dist/文件夹中创建构建

Version numbers for the builds are directly extracted from the versions installed in the local node_modules folder.

构建的版本数目直接从安装在本地的node_modules文件夹的版本中抽取出。

For creating new builds:为了创建新的构建

  1. Change package.json to require desired/up-to-date versions of the libraries 改变package.json去获取想要的/最新版本的库

package.json

{
"private": true,
"name": "browser-builds",
"version": "0.0.0",
"description": "Browser builds of ethereumjs libraries.",
"scripts": {
"build": "node build.js"
},
"repository": {
"type": "git",
"url": "git+https://github.com/ethereumjs/browser-builds.git"
},
"keywords": [
"ethereum",
"browser"
],
"author": "Alex Beregszaszi <alex@rtfs.hu>",
"license": "MIT",
"bugs": {
"url": "https://github.com/ethereumjs/browser-builds/issues"
},
"homepage": "https://github.com/ethereumjs/browser-builds#readme",
"dependencies": {//这里写了所有的库,你可以根据你自己的需求进行删减,并更改相应的版本
"ethereumjs-abi": "^0.6.2",
"ethereumjs-icap": "^0.3.1",
"ethereumjs-tx": "^1.3.1",
"ethereumjs-units": "^0.2.0",
"ethereumjs-vm": "^2.3.0",
"ethereumjs-wallet": "^0.6.0"
},
"devDependencies": {
"babel-preset-env": "^1.7.0",
"babel-preset-react": "^6.24.1",
"babelify": "^7.3.0",
"browserify": "^14.4.0",
"uglifyify": "^4.0.4"
}
}

  2.Reinstall/update local node_modules packages  重新安装/更新本地node_modules

运行npm install

  3.Run npm run build to generate new set of builds  运行npm run build命令去生成新构建集

返回:

userdeMBP:browser-builds-master user$ npm run build

> browser-builds@0.0. build /Users/user/browser-builds-master
> node build.js ***ethereumjs-all***
Creating debug version package dist/ethereumjs-all/ethereumjs-all---.js
Creating minified package dist/ethereumjs-all/ethereumjs-all---.min.js ***ethereumjs-vm***
Creating debug version package dist/ethereumjs-vm/ethereumjs-vm-2.5..js
Creating minified package dist/ethereumjs-vm/ethereumjs-vm-2.5..min.js ***ethereumjs-tx***
Creating debug version package dist/ethereumjs-tx/ethereumjs-tx-1.3..js
Creating minified package dist/ethereumjs-tx/ethereumjs-tx-1.3..min.js ***ethereumjs-icap***
Omitting debug version package dist/ethereumjs-icap/ethereumjs-icap-0.3..js (file exists)
Omitting minified package dist/ethereumjs-icap/ethereumjs-icap-0.3..min.js (file exists) ***ethereumjs-wallet***
Creating debug version package dist/ethereumjs-wallet/ethereumjs-wallet-0.6..js
Creating minified package dist/ethereumjs-wallet/ethereumjs-wallet-0.6..min.js ***ethereumjs-wallet-hd***
Creating debug version package dist/ethereumjs-wallet-hd/ethereumjs-wallet-hd-0.6..js ***ethereumjs-abi***
Omitting debug version package dist/ethereumjs-abi/ethereumjs-abi-0.6..js (file exists)
Omitting minified package dist/ethereumjs-abi/ethereumjs-abi-0.6..min.js (file exists)
Creating minified package dist/ethereumjs-wallet-hd/ethereumjs-wallet-hd-0.6..min.js ***ethereumjs-wallet-thirdparty***
Creating debug version package dist/ethereumjs-wallet-thirdparty/ethereumjs-wallet-thirdparty-0.6..js
Creating minified package dist/ethereumjs-wallet-thirdparty/ethereumjs-wallet-thirdparty-0.6..min.js

然后你的dist文件夹下就会得到你想要的构建了,然后你就能够在页面端使用这些构建了,就像上面的例子一样

ethereumjs/browser-builds的更多相关文章

  1. ethjs-1-了解

    https://github.com/ethjs/ethjs/blob/master/docs/user-guide.md Install npm install --save ethjs Usage ...

  2. 18 个最好的CSS框架用于提高开发效率

    根据维基百科,CSS框架是事先准备好的库,是为了让使用层叠样式表语言来美化网页更容易,更符合标准.在这篇文章中,我们已经收集了一些现成的框架,这将使你减少你的任务流程和代码.我们希望你会发现列表中的方 ...

  3. 前端工程师应该都了解的16个最受欢迎的CSS框架

    摘要: 今天给大家分享16个最受欢迎的CSS框架.这些是根据笔者的爱好以及相关查阅规整出来的.可能还有一些更棒的或者您更喜欢的没有列举出来.如果有,欢迎留言! Pure : CSS Framework ...

  4. ethereumjs/ethereumjs-tx

    https://github.com/ethereumjs/ethereumjs-tx A simple module for creating, manipulating and signing e ...

  5. Graded Browser Support

    ( The YUI Target Environments Matrix is here) About the Browser Test Baseline and Operating Systems ...

  6. Activating Browser Modes with Doctype

    原文地址:https://hsivonen.fi/doctype/ In order to deal both with content written according to Web standa ...

  7. Tech Stuff - Mobile Browser ID (User-Agent) Strings

    Tech Stuff - Mobile Browser ID (User-Agent) Strings The non-mobile stuff is here (hint: you get jerk ...

  8. ethereumjs/ethereumjs-wallet

    Utilities for handling Ethereum keys ethereumjs-wallet A lightweight wallet implementation. At the m ...

  9. ethereumjs/ethereumjs-icap

    https://github.com/ethereumjs/ethereumjs-icap ethereumjs-icap 安装: npm install ethereumjs-icap --save ...

随机推荐

  1. 一:Bootstrap-css样式

    页面大块布局: div.container 栅格系统: 一行分成 12 列 div.row div.col-md-12 div.col-xs-12 <div class="row&qu ...

  2. 167 -两个Sum II - 输入数组已排序

    给定已按升序排序的整数数组,找到两个数字,使它们相加到特定的目标数. 函数twoSum应返回两个数字的索引,以便它们加起来到目标,其中index1必须小于index2. 注意: 您返回的答案(inde ...

  3. Java设计模式浅谈

    1.java的设计模式可以分为3类: 创建型模式(5种):工厂模式,抽象工厂模式,建造者模式,单例模式,原型模式: 结构型模式(7种):适配器模式,装饰器模式,代理模式,外观模式,桥接模式,组合模式和 ...

  4. HDU2048 神,上帝以及老天爷 错排

    http://acm.hdu.edu.cn/showproblem.php?pid=2048 这是一道错排的题目 错排如下:http://baike.baidu.com/link?url=U2_H-4 ...

  5. 基于注解的简单SSH保存用户小案例

    需求:搭建SSH框架环境,使用注解进行相关的注入(实体类的注解,AOP注解.DI注入),保存用户信息 效果: 一.导依赖包 二.项目的目录结构 三.web.xml配置 <?xml version ...

  6. 浅谈ul布局以及table布局

    我个人对于某些言论说要注重html语义化在布局中的应用,我反而不怎么感冒,试试兼容IE7&&项目期相对较赶的情况下,我还是推荐快速开发为主,兼容性强为主. 如果布局中需要用户边框,推荐 ...

  7. python模拟登陆豆瓣——简单方法

    学爬虫有一段时间了,前面没有总结又重装了系统,导致之前的代码和思考都没了..所以还是要及时整理总结备份.下面记录我模拟登陆豆瓣的方法,方法一登上了豆瓣,方法二重定向到了豆瓣中“我的喜欢”列表,获取了第 ...

  8. vuex入门教程和思考 [转] 里面有几个实例

    Vuex基础概念 vuex中涉及的概念主要有下面几点,下面做个简单的介绍和理解. Vuex 官方文档:https://vuex.vuejs.org/zh-cn/ 官网有介绍,也有个demo shopp ...

  9. 微服务&spring cloud架构系列汇总

    为了方便查找,把微服务&微服务架构之spring cloud架构系列文章按时间正序整理了一下,记录如下:   1. 微服务架构之spring cloud 介绍 2. 微服务架构之spring ...

  10. 我为什么用docker-compose来打包开发环境

    BUILD, SHIP, RUN Docker is the world's leading software containerization platform Docker的出现,让虚拟技术更上一 ...