✏️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