✏️1.7 중간 점검: 두 파일(과 두 단계)로 분리됨

현재 코드는 두 개의 파일로 구성된다.

🧷 statement.js

import createStatementData from './createStatementData.js';

function statemnt(invoice, plays) {
  return renderPlainText(createStatementData(invoice, plays));
}

function renderPlainText(data, plays) {
  let result = `청구 내역(고객명): ${invocie.customer})\n`;
  
  for (let perf of invoice.performaces) {
    result += ` ${playFor(perf).name}: ${usd(perf.amount)} ($perf.audience}석)\n`;  
  
  result += `총액: ${usd(totalAmount())}\n`;	
  result += `적립 포인트: ${totalVolumeCredits()}점\n`;
  return result;
}

function htmlStatemnt(invoice, plays) {
  return renderHtml(createStatementData, plays));
}

function renderHtml(data) {
  let result = `<h1>청구 내역(고객명): ${data.customer})</h1>\n`;
  result += "<table>\n";
  
  ...
    
  return result;
}

function usd(aNumber) {
  return new Intl.NumberFormat("en-US", 
             { style: "currency", currency: "USD", 
      		   minimumFractionDigits: 2 }).format(aNumber/100);
}

🧷 createStatementData.js

44줄짜리 코드가 html을 제외해도 70줄이나 된다. 하지만 추가된 코드 덕분에 전체 로직을 구성하는 요소 각각이 뚜렷이 부각되고, 계산되는 부분과 출력 형식을 다루는 부분이 분리됐다. 모듈화하면서 각 부분이 하는 일과 그 부분들이 맞물려 돌아가는 과정을 파악하기 쉬워졌다.

프로그래밍에서만큼은 간결함보다는 명료함이 진화할 수 있는 소프트웨어의 정수이다. 모듈화한 덕분에 계산 코드를 중복하지 않고도 HTML 버전을 만들 수 있었다.

Last updated