>  기사  >  웹 프론트엔드  >  Node.js 스캐폴딩 구현 방법(자세한 튜토리얼)

Node.js 스캐폴딩 구현 방법(자세한 튜토리얼)

亚连
亚连원래의
2018-06-22 17:38:003093검색

이 글은 간단한 Node.js 스캐폴딩을 구현하는 방법을 주로 소개합니다. 편집자가 꽤 좋다고 생각해서 지금 공유하고 참고용으로 올려보겠습니다. 에디터를 따라가며 살펴볼까요

이유

업무상 관련 사용자에게 관련 개발 편의성을 제공하기 위한 스캐폴딩 개발이 필요합니다.

프런트 엔드 및 노드 운영에 대해 어느 정도 이해하고 있고 스캐폴딩 개발 프로세스를 이해하거나 스캐폴딩을 직접 구현해야 하는 사람들

에게 적합합니다.

Goal

  1. 설치를 위해 사용자에게 제공할 수 있는 간단한 비계를 개발합니다.

  2. 관련 프롬프트를 출력할 수 있습니다.

  3. 사용자 파일을 읽고 씁니다.

  4. 스캐폴딩에 쉘 스크립트를 사용하세요.

Steps

Developing scaffolding

Scaffolding의 초기 개발 프로세스는 일반적인 프런트엔드 프로젝트와 동일하며 항목 파일 command.js와 구성 파일 package.json이 필요합니다.

다른 구성 파일과 다르게 package.json 파일에 다음 항목을 추가해야 합니다.

{
 ...,
 "bin": {
    "cm-cli": "command.js"
  }
}

이 항목을 구성 파일에 추가한 후 구성의 루트 디렉터리에서 npm link 명령만 실행하면 됩니다. 즉, cm-cli --help 명령을 사용하여 로드된 cm-cli 스캐폴딩을 볼 수 있습니다.

스캐폴딩을 게시하면 npm install -g cm-cli 명령을 사용한 후 다른 사용자가 전역적으로 스캐폴딩을 사용할 수 있습니다.

사용자에게 프롬프트하기

댓글과 명령을 프롬프트하려면 npm install Commander를 사용하여 설치할 수 있는 Commander 패키지를 사용해야 합니다. (NPM 버전이 5보다 낮은 경우 package.json 구성 파일이 업데이트되도록 --save 매개 변수를 추가해야 합니다).

commander는 사용자 명령줄 입력 및 매개변수 구문 분석을 제공하는 강력한 기능입니다. 필요한 경우 관련 라이브러리 문서를 읽을 수 있습니다. 여기서는 가장 일반적으로 사용되는 두 가지 방법을 소개합니다.

option

은 사용자 정의 매개변수 개체를 초기화하고, 키워드 및 설명을 설정하고, 사용자 입력을 읽기 위한 매개변수도 설정할 수 있습니다. 구체적인 사용법은 다음과 같습니다.

const commander = require('commander');

commander.version('1.0.0')
  .option('-a, --aaa', 'aaaaa')
  .option('-b, --bbb', 'bbbbb')
  .option('-c, --ccc [name]', 'ccccc')
  .parse(process.argv);


if (commander.aaa) {
  console.log('aaa');
}

if (commander.bbb) {
  console.log('bbb');
}

if (commander.ccc) {
  console.log('ccc', commander.ccc);
}

구체적인 표시는 다음과 같습니다.

command

이 방법을 사용하면 명령줄에 명령을 추가할 수 있습니다. 사용자는 이 명령을 실행한 후 콜백의 논리를 실행할 수 있습니다. 구체적인 사용법은 다음과 같습니다.

commander
  .command(&#39;init <extensionId>&#39;)
  .description(&#39;init extension project&#39;)
  .action((extensionId) => {
    console.log(`init Extension Project "${extensionId}"`);
    // todo something you need
  });

구체적인 표시 효과는 다음과 같습니다.

사용자 파일 읽기 및 쓰기

위 단계를 통해 간단한 스캐폴딩을 완성할 수 있었습니다. 다음으로 사용자 구성을 읽고 사용자를 위한 일부 템플릿 파일을 생성해야 합니다.

파일 읽기

이제 일부 구성을 수행하려면 사용자의 cm-cli.json 구성 파일을 읽어야 합니다.

Node.js의 fs 파일 모듈을 사용하여 파일 진행 상황을 읽을 수 있습니다. 여기서는 별 어려움이 없으므로 생략하겠습니다.

파일 템플릿 쓰기

미리 CDN에 템플릿 파일을 저장한 후 로컬에서 읽어온 해당 스캐폴딩 구성 파일을 기반으로 템플릿을 다운로드합니다.

참고: 스캐폴드에서 읽은 경로는 사용자가 사용할 때의 현재 경로이므로 읽기 위해 스캐폴드에 템플릿 파일을 저장할 방법이 없습니다.

요청과 같은 라이브러리를 사용하여 파일을 다운로드하고 작업 단계를 단순화할 수 있습니다. npm install request`를 실행하여 설치합니다.

참고: 파일을 쓸 때 덮어쓰기 전에 먼저 파일이 존재하는지 확인하는 것이 좋습니다.

쉘 스크립트 사용

Node.js에서 제공하는 API 기능을 보면 파일 작업을 수행하기 위해 쉘 스크립트를 사용하는 것을 선호하는 사람들도 있습니다. 다행히도 우리는 스캐폴딩에 node-cmd를 도입하여 쉘 스크립트에 대한 지원을 활성화할 수도 있습니다. npm install node-cmd를 실행하여 설치합니다.

구체적인 예는 다음과 같습니다.

commander
  .command(&#39;init <extensionId>&#39;)
  .description(&#39;init extension project&#39;)
  .action((extensionId) => {
    id = extensionId;
    console.log(`init Extension Project "${extensionId}"`);

    cmd.get(
      `
      mkdir -p static/${extensionId}

      mkdir tmp
      mkdir tmp/source-file
      mkdir tmp/build-file
      curl -o tmp/source-file/index.js https://xxxxxxxx.com?filename=index.js
      touch tmp/source-file/index.css

      curl -o tmp/build-file/server.js https://xxxxxxxx.com?filename=server.js
      curl -o tmp/build-file/router.js https://xxxxxxxx.com?filename=router.js
      curl -o tmp/build-file/package.json https://xxxxxxxx.com?filename=package.json
      
      cp tmp/source-file/* static/${extensionId}
      cp tmp/build-file/* ./
      rm -fr tmp
      npm install
      `,
      (err, data) => {
        console.log(data)
        if (!err) {
          console.log(&#39;init success&#39;);
          return;
        }

        console.error(&#39;init error&#39;);
      });
  });

셸 스크립트를 사용하여 빠르게 폴더를 만들고 파일 템플릿을 다운로드할 수 있습니다.

요약

터미널에서 스캐폴딩을 빠르게 실행하고 싶다면 package.json 구성 파일에 관련 필드를 추가하면 됩니다.

스캐폴딩은 관련 터미널 입력을 읽을 수 있어야 하며, 빠른 개발을 위해 커맨더 라이브러리를 사용할 수 있습니다.

스캐폴딩은 Shell 스크립트를 실행할 수 있어야 하며 node-cmd 라이브러리를 사용하여 요구 사항을 빠르게 구현할 수 있습니다.

위 내용은 모두를 위해 제가 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다.

관련 기사:

JS+캔버스를 사용하여 원뿔을 만드는 방법

JS 정렬 알고리즘 요약 정보

js 이벤트 루프 메커니즘 정보(자세한 튜토리얼)

Javascript를 사용하여 QQ 구현하는 방법 우주 사진 앨범 전시

PC WeChat 스캔 코드 로그인을 사용자 정의하는 방법

jade 템플릿 엔진 사용에 대한 세부 정보

JS Hill 정렬 알고리즘 정보(자세한 튜토리얼)

위 내용은 Node.js 스캐폴딩 구현 방법(자세한 튜토리얼)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.