ES3框架

Easy老师的EasyStart3框架

项目地址 https://gitlab.com/easychen/easystart3

Clone到本地之后yarn start就可以开始用了

课程中robo ns Editor这步涉及robo这个命令

提问了老师, robo 命令是 https://robo.li/ 提供的,需要自己按教程安装。

wget http://robo.li/robo.phar
chmod +x robo.phar && sudo mv robo.phar /usr/bin/robo

然后项目根目录下放文件 RoboFile.php

<?php
define( "SRC" , __DIR__ . '/src' );

class RoboFile extends \Robo\Tasks
{
    /**
     * git commit
     */
    public function git( $m = 'update' )
    {
        $this->_exec("git add . && git commit -m '" . $m . "' && git push -u origin master");
    }

    /**
     * 创建一个新的页面 快捷
     */
    public function ns( $name = null )
    {
        return $this->newScreen( $name );
    }

    /**
     * 创建一个新的组件 快捷
     */
    public function nc( $name = null )
    {
        return $this->newComponent( $name );
    }

    
    /**
     * 创建一个新的页面
     */
    public function newScreen( $name = null )
    {
        return $this->copy_template( $name , 'screen' );
    }

    /**
     * 创建一个新的组件
     */
    public function newComponent( $name = null )
    {
        return $this->copy_template( $name , 'component' );
    }

    private function copy_template( $name , $type = 'component' )
    {
        
        $type = basename( $type );
        if( $type != 'component' ) $type = 'screen';
        
        if( $name === null ) $name =$this->ask("请输入组件名称");
        if( strlen( $name ) < 1 )
        {
            $this->say("错误组件的名称");
            return false;
        } 

        $file_path = SRC . '/' . $type . '/'. ucfirst( $name ) . '.js';

        if( file_exists( $file_path ) )
        {
            $this->say("组件已存在");
            return false;
        }
        
        $file_tmp = SRC .'/_template/'. $type .'.js';
        if( !file_exists( $file_tmp ) )
        {
            $this->say("模板文件 $file_tmp 不存在");
            return false;
        }

        $content = file_get_contents( $file_tmp );
        $content = str_replace( 'ClassNamePlaceHolder' ,  ucfirst( $name ) , $content);

        file_put_contents( $file_path , $content );
        
        if( $type == 'component' ) $path = '..';
        else $path = '.';
        $this->_exec(" echo \"import " . $name . " from '" . $path . "/" . $type . "/" . $name . "'; \" | node_modules/copy-paste-cli/cli.js  copy");

        $this->say( "组件初始化完成" );

    }
}

Express框架初始化

一直在云沙箱里学习Express开发,总归还是要自己折腾一遍部署的。

MDN的教程可实在是亲妈级手把手教学:

完整的 Express 本地开发环境包括 Nodejs、NPM 包管理器和 Express 应用生成器(可选)。

折腾的环境为Ubuntu 18.04

安装node.js

  1. curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash -
  2. sudo apt-get install -y nodejs

检查安装:

  1. eric@ubuntu-v:~/myapp$ node -v
  2. v10.19.0
  3. eric@ubuntu-v:~/myapp$ npm -v
  4. 6.13.4

安装Express应用生成器

  • npm install express-generator -g

创建应用

  1. express helloworld
  2. cd helloworld
  3. npm install
  4. DEBUG=helloworld:* npm start

windows平台上,又尝试了一下用yarn

首先按顺序安装nodejs和yarn的msi包

  1. yarn global add express-generator
  2. express myapp
  3. cd myapp
  4. yarn install