• 以太坊:编写外部脚本


    编写外部脚本

    Often you may want to run external scripts that interact with your contracts. Truffle provides an easy way to do this, bootstrapping your contracts based on your desired network and connecting to your Ethereum client automatically per your project configuration.

    命令

    To run an external script, perform the following:

    $ truffle exec <path/to/file.js>
    

    File structure

    In order for external scripts to be run correctly, Truffle expects them to export a function that takes a single parameter as a callback:

    module.exports = function(callback) {
      // perform actions
    }
    

    You can do anything you’d like within this script, so long as the callback is called when the script finishes. The callback accepts an error as its first and only parameter. If an error is provided, execution will halt and the process will return a non-zero exit code.

    第三方插件命令

    **Note**: This feature is new and still in a barebones state. Please let us know how we can improve it!

    Plugin installation / usage

    1. Install the plugin from NPM.

    npm install --save-dev truffle-plugin-hello
    
    1. Add a plugins section to your Truffle config.

      module.exports = {
        /* ... rest of truffle-config */
      
        plugins: [
          "truffle-plugin-hello"
        ]
      }
      
    2. Run the command

    $ truffle run hello
    Hello, World!
    

    Creating a custom command plugin

    1. Implement the command as a Node module with a function as its default export.

      Example: hello.js

      /**
       * Outputs `Hello, World!` when running `truffle run hello`,
       * or `Hello, ${name}` when running `truffle run hello [name]`
       * @param {Config} config - A truffle-config object.
       * Has attributes like `truffle_directory`, `working_directory`, etc.
       */
       module.exports = async (config) => {
        // config._ has the command arguments.
        // config_[0] is the command name, e.g. "hello" here.
        // config_[1] starts remaining parameters.
        if (config.help) {
       console.log(`Usage: truffle run hello [name]`);
           done(null, [], []);	
       return;
        }
      
        let name = config._.length > 1 ? config._[1] : 'World!';
        console.log(`Hello, ${name}`);
      }
      
    2. Define a truffle-plugin.json file to specify the command. Example: truffle-plugin.json

      {
        "commands": {
      "hello": "hello.js"
        }
      }
      
    3. Publish to NPM

      npm publish
  • 相关阅读:
    shutil的一些基本用法
    python用random产生验证码,以及random的一些其他用法
    hashlib 文件校验,MD5动态加盐返回加密后字符
    python中logging日志基本用法,和进程安全问题
    用递归函数得到目录下的所有文件
    python装饰器
    列表推导式三种模式和生成器
    vue.js响应式原理解析与实现
    Promise详解
    三分钟教你同步 Visual Studio Code 设置
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13313078.html
Copyright © 2020-2023  润新知