ãã³ãã¬ãŒãããŒã¹ã®ããã³ããšã³ãã³ãŒãçæã®åãæ¢æ±ããŸããããå¹çæ§ãé«ããäžè²«æ§ã確ä¿ããã°ããŒãã«ããŒã ã®éçºã¯ãŒã¯ãããŒãå¹çåããæ¹æ³ãåŠã³ãŸãã
ããã³ããšã³ãã³ãŒãçæïŒãã³ãã¬ãŒãããŒã¹ã®ã¢ãããŒãã§éçºãå é
ããã³ããšã³ãéçºã®ãã€ãããã¯ãªäžçã§ã¯ãå¹çæ§ãšã¹ããŒããæéèŠã§ããæŽç·Žãããã€ã³ã¿ã©ã¯ãã£ããªã€ã³ã¿ãŒãã§ãŒã¹ã«å¯ŸãããŠãŒã¶ãŒã®æåŸ ãé«ãŸãç¶ããäžãéçºããŒã ã¯ã¯ãŒã¯ãããŒãå¹çåããããã®é©æ°çãªæ¹æ³ãåžžã«æš¡çŽ¢ããŠããŸãã倧ããªå¢ããå¢ããŠãã匷åãªæŠç¥ã®1ã€ããããã³ããšã³ãã³ãŒãçæãç¹ã«ãã³ãã¬ãŒãããŒã¹ã®éçºã§ãããã®ã¢ãããŒãã¯ãå®çŸ©æžã¿ã®æ§é ãšãã¿ãŒã³ã掻çšããŠãå埩çãŸãã¯å®åçãªã³ãŒãã®äœæãèªååããéçºè ãããè€éã§åµé çãªãåªãããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ã®æ§ç¯ã«éäžã§ããããã«ããŸãã
éçºè ã®ã°ããŒãã«ãªãªãŒãã£ãšã³ã¹ã«ãšã£ãŠããã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæãçè§£ããå®è£ ããããšã¯ãå Žæãåã ã®ã³ãŒãã£ã³ã°ã¹ã¿ã€ã«ã«é¢ä¿ãªãã倿§ãªããŒã ãšãããžã§ã¯ãå šäœã§äžè²«æ§ãè²ããã²ãŒã ãã§ã³ãžã£ãŒãšãªãåŸãŸãã
ããã³ããšã³ãã³ãŒãçæãšã¯ïŒ
æ¬è³ªçã«ãããã³ããšã³ãã³ãŒãçæã«ã¯ãå®çŸ©æžã¿ã®ãã³ãã¬ãŒããšå ¥åãã©ã¡ãŒã¿ã«åºã¥ããŠããœãŒã¹ã³ãŒããèªåçã«çæããããã®ããŒã«ãŸãã¯ã¹ã¯ãªããã®äœ¿çšãå«ãŸããŸããå埩çãªã³ãŒãæ§é ãæåã§èšè¿°ãã代ããã«ãéçºè ã¯åžæããåºåãæŠèª¬ãããã³ãã¬ãŒããå®çŸ©ã§ããçæããŒã«ãç¹å®ã®ããŒã¿ãŸãã¯æ§æã§ãããå ¥åããŸããããã¯ç¹ã«ä»¥äžã«åœ¹ç«ã¡ãŸãã
- å®åã³ãŒãïŒäžè¬çãªãã¡ã€ã«æ§é ãã³ã³ããŒãã³ãèšå®ããŸãã¯æ§æãã¡ã€ã«ã®çæã
- ããŒã¿ããªãã³UIïŒããŒã¿ã¹ããŒããŸãã¯APIã¬ã¹ãã³ã¹ããçŽæ¥ãŠãŒã¶ãŒã€ã³ã¿ãŒãã§ãŒã¹èŠçŽ ãäœæã
- ã³ã³ããŒãã³ãã®ããªãšãŒã·ã§ã³ïŒããŸããŸãªæ§æãŸãã¯ç¶æ ãæã€UIã³ã³ããŒãã³ãã®è€æ°ã®ããŒãžã§ã³ãçæã
- CRUDæäœïŒåºæ¬çãªäœæãèªã¿åããæŽæ°ãåé€ã€ã³ã¿ãŒãã§ãŒã¹ã®äœæãèªååã
ãã³ãã¬ãŒãããŒã¹ã®éçºã®å°é
ãã³ãã¬ãŒãããŒã¹ã®éçºã¯ãã³ãŒãçæã®ç¹å®ã®éåžžã«å¹æçãªåœ¢åŒã§ããããã¯ãã³ãŒãã®æ§é ãšã¬ã€ã¢ãŠãããå«ãŸãããåŠçãããç¹å®ã®ããŒã¿ããåé¢ãããšããååã«åºã¥ããŠããŸããéçºè åãã®ã¡ãŒã«ããŒãžã®ãããªãã®ãšèããŠãã ããã
ãã³ãã¬ãŒãã¯ãHTMLæ§é ãåºæ¬çãªCSSã»ã¬ã¯ã¿ãã³ã³ããŒãã³ãã®ã©ã€ããµã€ã¯ã«ã¡ãœããããŸãã¯APIåŒã³åºãæ§é ãªã©ãã³ãŒãã®éçãªéšåãå®çŸ©ããŸããæ¬¡ã«ããã®ãã³ãã¬ãŒãå ã®å€æ°ãŸãã¯ãã¬ãŒã¹ãã«ããŒã¯ãç¹å®ã®å€ãŸãã¯åçããŒã¿ã§åããããç¹å®ã®ããŒãºã«åãããŠèª¿æŽãããå®å šãªã³ãŒããçæãããŸãã
ãã®æ¹æ³è«ã¯ããœãããŠã§ã¢éçºã®åºæ¬çãªååã§ããDon't Repeat Yourself (DRY)ãšããèãæ¹ã«æ·±ãæ ¹ãããŠããŸããåå©çšå¯èœãªãã³ãã¬ãŒããäœæããããšã«ãããéçºè ã¯åé·ãªã³ãŒãã£ã³ã°ãåé¿ãããšã©ãŒã®å¯èœæ§ãæžãããä¿å®æ§ãåäžãããŸãã
ãã³ãã¬ãŒãããŒã¹ã®ããã³ããšã³ãã³ãŒãçæã®äž»ãªå©ç¹
ãã³ãã¬ãŒãããŒã¹ã®ã¢ãããŒããããã³ããšã³ãã³ãŒãçæã«æ¡çšããå©ç¹ã¯æ°å€ããããç¹ã«åœéçãªéçºããŒã ã«ãšã£ãŠå€§ããªåœ±é¿ããããŸãã
- éçºé床ã®åäžïŒäžè¬çãªã³ãŒããã¿ãŒã³ã®äœæãèªååãããšãéçºæéãå€§å¹ ã«ççž®ãããŸããå埩çãªã³ãŒãè¡ãèšè¿°ãã代ããã«ãéçºè ã¯åäžã®ã³ãã³ãã§ã³ã³ããŒãã³ããŸãã¯ã¢ãžã¥ãŒã«å šäœãçæã§ããŸããããã¯ãå³ããçŽæãéæããç«¶äºã®æ¿ããã°ããŒãã«åžå Žã§è£œåã®æäŸãå éããããã«äžå¯æ¬ ã§ãã
- äžè²«æ§ãšæšæºåã®åŒ·åïŒãã³ãã¬ãŒãã¯ããããžã§ã¯ãå šäœãŸãã¯çµç¹å šäœã§ãäžè²«ããã³ãŒãã£ã³ã°ã¹ã¿ã€ã«ãæ§é ãããã³ãã¹ããã©ã¯ãã£ã¹ã®éµå®ã培åºããŸããããã¯ãåäžæ§ã®ç¶æãé£ããå€§èŠæš¡ã§åæ£ããããŒã ã«ãšã£ãŠéåžžã«è²Žéã§ããå Žæãèæ¯ã«é¢ä¿ãªãããã¹ãŠã®éçºè ãåã確ç«ããããã¿ãŒã³ã䜿çšããŠäœæ¥ããŠããããšãä¿èšŒããŸãã
- ãšã©ãŒãšãã°ã®åæžïŒå®åã³ãŒããæåã§èšè¿°ãããšãã¿ã€ããã¹ãè«çãšã©ãŒãçºçãããããªããŸããä¿¡é Œã§ãããã³ãã¬ãŒãããã³ãŒããçæããããšã«ããããã®ãããªãã°ãçºçãããªã¹ã¯ãå€§å¹ ã«åæžãããŸããããã«ãããããå®å®ããä¿¡é Œæ§ã®é«ãã¢ããªã±ãŒã·ã§ã³ãå®çŸããŸãã
- ä¿å®æ§ã®åäžïŒã³ãŒãããã³ãã¬ãŒãããçæããããšãäžè¬çãªãã¿ãŒã³ãžã®æŽæ°ãŸãã¯å€æŽããã³ãã¬ãŒãèªäœã§è¡ãããšãã§ããŸããã³ãŒããåçæãããšããããã®å€æŽããã¹ãŠã®ã€ã³ã¹ã¿ã³ã¹ã«äŒæãããããã倿°ã®ãã¡ã€ã«ã«ãããæåã®ãªãã¡ã¯ã¿ãªã³ã°ãããã¡ã³ããã³ã¹ãã¯ããã«å¹ççã«ãªããŸãã
- ãããã¿ã€ãã³ã°ã®å éïŒè¿ éãªãããã¿ã€ãã³ã°ãšMinimum Viable Product (MVP)éçºã®å Žåããã³ãã¬ãŒãããŒã¹ã®çæã«ãããããŒã ã¯æ©èœçãªãŠãŒã¶ãŒã€ã³ã¿ãŒãã§ãŒã¹ããã°ããçµã¿ç«ãŠãããšãã§ããŸããããã«ãããäžçäžã®ã¹ããŒã¯ãã«ããŒãšã®ã¢ã€ãã¢ã®è¿ éãªååŸ©ãšæ€èšŒãå¯èœã«ãªããŸãã
- æ°ããéçºè ã®ããã®ããè¯ããªã³ããŒãã£ã³ã°ïŒæ°ããããŒã ã¡ã³ããŒã¯ã確ç«ããããã³ãã¬ãŒããšçæããã»ã¹ãçè§£ããããšã§ãããã«çè§£ãæ·±ããããšãã§ããŸããããã«ãããåŠç¿æ²ç·ãççž®ãããç¹å®ã®ãããžã§ã¯ãã³ãŒãããŒã¹ã«é¢ããäºåã®çµéšã«é¢ä¿ãªãã忥ããæå³ã®ããè²¢ç®ãããããšãã§ããŸãã
- è€éãªã¢ãŒããã¯ãã£ãä¿é²ïŒè€éãªã³ã³ããŒãã³ãéå±€ãŸãã¯ããŒã¿ã¢ãã«ãæã€ãããžã§ã¯ãã®å Žåããã³ãã¬ãŒãã¯ãå¿ èŠãªè¶³å Žãšçžäºæ¥ç¶ãèªåçã«çæããããšã«ãããè€éãã管çããã®ã«åœ¹ç«ã¡ãŸãã
ãã³ãã¬ãŒãããŒã¹ã®ããã³ããšã³ãã³ãŒãçæã®äžè¬çãªãŠãŒã¹ã±ãŒã¹
ãã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæã¯çšéãåºããããŸããŸãªããã³ããšã³ãéçºã¿ã¹ã¯ã«é©çšã§ããŸããæãäžè¬çã§åœ±é¿åã®ãããŠãŒã¹ã±ãŒã¹ã次ã«ç€ºããŸãã
1. UIã³ã³ããŒãã³ãã®çæ
ããã¯ããããæãäžè¬çãªã¢ããªã±ãŒã·ã§ã³ã§ããéçºè ã¯ããã¿ã³ãå ¥åãã£ãŒã«ããã«ãŒããã¢ãŒãã«ãããã²ãŒã·ã§ã³ããŒãªã©ãäžè¬çãªUIèŠçŽ ã®ãã³ãã¬ãŒããäœæã§ããŸãããããã®ãã³ãã¬ãŒãã¯ãããã¹ãã³ã³ãã³ããè²ãã€ãã³ããã³ãã©ãŒãããã³ç¹å®ã®ç¶æ ïŒç¡å¹ãèªã¿èŸŒã¿ãªã©ïŒãªã©ã®å°éå ·ãåãå ¥ããããã«ãã©ã¡ãŒã¿ãŒåã§ããŸãã
äŸïŒåå©çšå¯èœãªãã«ãŒããã³ã³ããŒãã³ãã®ãã³ãã¬ãŒããæ³åããŠãã ããããã³ãã¬ãŒãã¯ãåºæ¬çãªHTMLæ§é ãäžè¬çãªCSSã¯ã©ã¹ãç»åãã¿ã€ãã«ã説æãããã³ã¢ã¯ã·ã§ã³ã®slotsãå®çŸ©ããå ŽåããããŸããéçºè ã¯ãåslotã«ç¹å®ã®ããŒã¿ãæäŸããããšã«ããããProductCardããçæã§ããŸãã
ãã³ãã¬ãŒãïŒæŠå¿µçïŒïŒ
<div class="card">
<img src="{{imageUrl}}" alt="{{imageAlt}}" class="card-image"/>
<div class="card-content">
<h3 class="card-title">{{title}}</h3>
<p class="card-description">{{description}}</p>
<div class="card-actions">
{{actions}}
</div>
</div>
</div>
çæå ¥åïŒ
{
"imageUrl": "/images/product1.jpg",
"imageAlt": "Product 1",
"title": "Premium Widget",
"description": "A high-quality widget for all your needs.",
"actions": "<button>Add to Cart</button>"
}
ããã«ãããçµ±åã®æºåãã§ããå®å šã«åœ¢æããããProductCardãã³ã³ããŒãã³ããçæãããŸãã
2. ãã©ãŒã çæ
è€æ°ã®å ¥åãã£ãŒã«ããæ€èšŒã«ãŒã«ãããã³éä¿¡ããžãã¯ã䜿çšããŠãã©ãŒã ãäœæããããšã¯é¢åãªå ŽåããããŸãããã³ãã¬ãŒãããŒã¹ã®çæã¯ããã£ãŒã«ãã®ã¹ããŒãïŒååãã¡ãŒã«ããã¹ã¯ãŒããæ€èšŒã«ãŒã«ãªã©ïŒãååŸãã察å¿ããHTMLãã©ãŒã èŠçŽ ãå ¥åç¶æ ãããã³åºæ¬çãªæ€èšŒããžãã¯ãçæããããšã«ããããããèªååã§ããŸãã
äŸïŒãŠãŒã¶ãŒãããã¡ã€ã«ãã£ãŒã«ããå®çŸ©ããJSONã¹ããŒãïŒ
[
{ "name": "firstName", "label": "First Name", "type": "text", "required": true },
{ "name": "email", "label": "Email Address", "type": "email", "required": true, "validation": "email" },
{ "name": "age", "label": "Age", "type": "number", "min": 18 }
]
次ã«ããã³ãã¬ãŒãã¯ãã®ã¹ããŒãã䜿çšããæ¬¡ã®ããã«çæã§ããŸãã
<div class="form-group">
<label for="firstName">First Name*</label>
<input type="text" id="firstName" name="firstName" required/>
</div>
<div class="form-group">
<label for="email">Email Address*</label>
<input type="email" id="email" name="email" required/>
</div>
<div class="form-group">
<label for="age">Age</label>
<input type="number" id="age" name="age" min="18"/>
</div>
3. APIã¯ã©ã€ã¢ã³ããšããŒã¿ãã§ããããžãã¯
RESTful APIãŸãã¯GraphQLãšã³ããã€ã³ããæäœããå Žåãéçºè ã¯ãªã¯ãšã¹ãã®äœæãã¬ã¹ãã³ã¹ã®åŠçãèªã¿èŸŒã¿/ãšã©ãŒç¶æ ã®ç®¡çã«åæ§ã®ã³ãŒããèšè¿°ããããšããããããŸãããã³ãã¬ãŒãã¯ãAPIãšã³ããã€ã³ãå®çŸ©ãŸãã¯GraphQLã¹ããŒãã«åºã¥ããŠãããŒã¿ãã§ããçšã®é¢æ°ãçæã§ããŸãã
äŸïŒ`/api/users/{id}`ã®ãããªREST APIãšã³ããã€ã³ãã®å Žåããã³ãã¬ãŒãã¯JavaScript颿°ãçæã§ããŸãã
async function getUserById(id) {
try {
const response = await fetch(`/api/users/${id}`);
if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`);
}
const data = await response.json();
return data;
} catch (error) {
console.error("Error fetching user:", error);
throw error;
}
}
ããã¯ãOpenAPI仿§ãŸãã¯åæ§ã®APIå®çŸ©ããã¥ã¡ã³ãã«åºã¥ããŠãAPIãµãŒãã¹ã¢ãžã¥ãŒã«å šäœãçæããããã«ããã«æœè±¡åã§ããŸãã
4. ã«ãŒãã£ã³ã°ãšããã²ãŒã·ã§ã³ã®èšå®
Single Page Applications (SPAs)ã®å Žåãã«ãŒãã®èšå®ã«ã¯å埩çãªæ§æãå«ãŸããå ŽåããããŸãããã³ãã¬ãŒãã¯ãReact RouterãŸãã¯Vue Routerã®ãããªãã¬ãŒã ã¯ãŒã¯ã®ã«ãŒãå®çŸ©ããããŒãžãšãã®å¯Ÿå¿ããã³ã³ããŒãã³ãã®ãªã¹ãã«åºã¥ããŠçæã§ããŸãã
5. ãããžã§ã¯ãã®ã¹ãã£ãã©ãŒã«ãã£ã³ã°ãšå®åã³ãŒã
æ°ãããããžã§ã¯ããéå§ããããæ°ããæ©èœã¢ãžã¥ãŒã«ã远å ãããããå Žåãéåžžãå¿ èŠãªäžé£ã®æšæºãã¡ã€ã«ãšãã£ã¬ã¯ããªããããŸãïŒã³ã³ããŒãã³ããã¡ã€ã«ããã¹ããã¡ã€ã«ãCSSã¢ãžã¥ãŒã«ãã¹ããŒãªãŒããã¯æ§æãªã©ïŒãã³ãŒãçæããŒã«ã¯ããã®åææ§é ãèªåçã«äœæããã»ããã¢ããæéãå€§å¹ ã«ç¯çŽã§ããŸãã
ãã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæã®ããã®ããŒã«ãšãã¯ãããžãŒ
ãã³ãã¬ãŒãããŒã¹ã®ããã³ããšã³ãã³ãŒãçæã容æã«ããããã«ãããŸããŸãªããŒã«ãšã©ã€ãã©ãªãååšããããŸããŸãªããŒãºãšå¥œã¿ã«å¯Ÿå¿ããŠããŸããäž»ãªäŸã次ã«ç€ºããŸãã
- YeomanïŒãããžã§ã¯ãæ§é ãšãã¡ã€ã«ãäœæããããã«ãžã§ãã¬ãŒã¿ãŒïŒNode.jsã§æ§ç¯ïŒã䜿çšããã人æ°ã®ã¹ãã£ãã©ãŒã«ãã£ã³ã°ããŒã«ã§ããéçºè ã¯ãç¹å®ã®ããŒãºã«åãããŠã«ã¹ã¿ã Yeomanãžã§ãã¬ãŒã¿ãŒãäœæã§ããŸãã
- PlopïŒããã³ããšã³ãã®ã¹ãããããšå®åã³ãŒããç°¡åã«äœæã§ãããã€ã¯ããžã§ãã¬ãŒã¿ãŒãã¬ãŒã ã¯ãŒã¯ãã·ã³ãã«ããšæè»æ§ã§ç¥ãããŠãããã³ã³ããŒãã³ããã¢ãžã¥ãŒã«ã®çæã«ãã䜿çšãããŸãã
- HygenïŒã³ãŒãçæãã³ãã¬ãŒããç°¡åã«æŽçãåå©çšãå ±æã§ããã³ãŒããžã§ãã¬ãŒã¿ãŒãé«åºŠãªæ§æãå¯èœã§ãè€éãªçæã¿ã¹ã¯ãåŠçã§ããŸãã
- ã«ã¹ã¿ã ã¹ã¯ãªããïŒäŸïŒNode.jsãPythonïŒïŒé«åºŠã«å ·äœçãŸãã¯çµ±åãããã¯ãŒã¯ãããŒã®å Žåãéçºè ã¯Node.jsïŒHandlebarsãEJSãªã©ã®ã©ã€ãã©ãªã掻çšãããã³ãã¬ãŒãäœæïŒãPythonãªã©ã®èšèªã䜿çšããŠã«ã¹ã¿ã ã¹ã¯ãªãããèšè¿°ã§ããŸããããã«ããæå€§ã®å¶åŸ¡ãå¯èœã«ãªããŸãããçæã·ã¹ãã èªäœã«ã¯ããå€ãã®éçºåªåãå¿ èŠã§ãã
- ãã¬ãŒã ã¯ãŒã¯åºæã®CLIïŒå€ãã®ããã³ããšã³ããã¬ãŒã ã¯ãŒã¯ã«ã¯ãã³ãŒãçææ©èœãå«ãç¬èªã®ã³ãã³ãã©ã€ã³ã€ã³ã¿ãŒãã§ã€ã¹ïŒCLIïŒãä»å±ããŠããŸããããšãã°ãAngular CLIïŒ`ng generate component`ã`ng generate service`ïŒãšCreate React AppïŒçæã«éç¹ã¯çœ®ããŠããŸããããå å®ãªåºç€ãæäŸããŸãïŒã¯ãäžè¬çãªæ§é ãããŒãã¹ãã©ããããæ¹æ³ãæäŸããŸããVue CLIã¯ãã³ã³ããŒãã³ããšãããžã§ã¯ãã®ãžã§ãã¬ãŒã¿ãŒãæäŸããŠããŸãã
- API仿§ããŒã«ïŒäŸïŒOpenAPI GeneratorãGraphQL Code GeneratorïŒïŒãããã®ããŒã«ã¯ãAPI仿§ããçŽæ¥ã¯ã©ã€ã¢ã³ãåŽã®ã³ãŒãïŒAPIãµãŒãã¹é¢æ°ãããŒã¿åãªã©ïŒãçæã§ãããããããã¯ãšã³ããµãŒãã¹ãšã®çµ±åãæåã§è¡ãæéãå€§å¹ ã«åæžã§ããŸãã
ãã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæãå®è£ ããããã®ãã¹ããã©ã¯ãã£ã¹
ã¡ãªãããæå€§éã«é«ããæœåšçãªèœãšã穎ãåé¿ããã«ã¯ããã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæãå®è£ ãããšãã«æŠç¥çãªã¢ãããŒããæ¡çšããããšãäžå¯æ¬ ã§ãã以äžã«ãããã€ãã®ãã¹ããã©ã¯ãã£ã¹ã瀺ããŸãã
1. æç¢ºã§é©åã«å®çŸ©ããããã³ãã¬ãŒãããå§ãã
å ç¢ã§æè»ãªãã³ãã¬ãŒãã®äœæã«æéããããŸããæ¬¡ã®ããšã確èªããŸãã
- ãã©ã¡ãŒã¿åå¯èœïŒããŸããŸãªå ¥åãåãå ¥ããŠãããŸããŸãªåºåãçæããããã«ãã³ãã¬ãŒããèšèšããŸãã
- ä¿å®å¯èœïŒãã³ãã¬ãŒããã¯ãªãŒã³ã§ãæŽçãããçè§£ããããç¶æ ã«ä¿ã¡ãŸãã
- ããŒãžã§ã³ç®¡çïŒå€æŽã远跡ãã广çã«ã³ã©ãã¬ãŒã·ã§ã³ããããã«ãããŒãžã§ã³ç®¡çã·ã¹ãã ã«ãã³ãã¬ãŒããä¿åããŸãã
2. ãã³ãã¬ãŒããçŠç¹ãçµã£ãŠã¢ãžã¥ãŒã«åãã
å€ãã®ããšãè¡ãããšããã¢ããªã·ãã¯ãªãã³ãã¬ãŒãã®äœæãé¿ããŠãã ãããè€éãªçæã¿ã¹ã¯ããçµã¿åããããåå©çšãããã§ãããããå°ããããã管çãããããã³ãã¬ãŒãã«åå²ããŸãã
3. ãã«ãããã»ã¹ãšçµ±åãã
ãã«ããã€ãã©ã€ã³ãŸãã¯éçºã¹ã¯ãªããã«çµ±åããããšã«ãããçæããã»ã¹ãèªååããŸããããã«ãããéçºäžãŸãã¯ãããã€äžã«æåã§ä»å ¥ããããšãªããå¿ èŠã«å¿ããŠã³ãŒããçæãŸãã¯æŽæ°ãããããã«ãªããŸãã
4. ãã³ãã¬ãŒããšçæããã»ã¹ãææžåãã
æç¢ºãªããã¥ã¡ã³ãã¯ãç¹ã«ã°ããŒãã«ããŒã ã«ãšã£ãŠäžå¯æ¬ ã§ãã以äžã説æããŸãã
- åãã³ãã¬ãŒããçæãããã®ã
- åãã³ãã¬ãŒããåãå ¥ãããã©ã¡ãŒã¿ã
- çæããŒã«ã®äœ¿ç𿹿³ã
- ãã³ãã¬ãŒãã®ä¿åå Žæã
5. çæãããã³ãŒããæ éã«æ±ã
ãã³ãã¬ãŒãããçæãããã³ãŒãã¯ãéåžžãæåã§ç·šéããããšãç®çãšããŠããªãããšãçè§£ããŠãã ãããæ§é ãŸãã¯ããžãã¯ã倿Žããå¿ èŠãããå Žåã¯ããã³ãã¬ãŒãã倿ŽããŠããã³ãŒããåçæããå¿ èŠããããŸããäžéšã®ããŒã«ã§ã¯ãçæãããã³ãŒããããããããŸãã¯æ¡åŒµã§ããŸãããããã«ããè€éããå¢ãå¯èœæ§ããããŸãã
6. ã¬ããã³ã¹ãšæææš©ã確ç«ãã
ãã³ãã¬ãŒãã®äœæãä¿å®ãããã³æŽæ°ãæ åœãã人ãå®çŸ©ããŸããããã«ãããã³ãŒãçæã·ã¹ãã ãå ç¢ã§ããããããžã§ã¯ãã®ããŒãºã«æ²¿ã£ããã®ã«ãªãããšãä¿èšŒãããŸãã
7. ç®çã«åã£ãé©åãªããŒã«ãéžæãã
ãããžã§ã¯ãã®è€éããããŒã ã®ããŒã«ã«å¯Ÿããæ £ããããã³çµ±åèŠä»¶ã«åºã¥ããŠãå©çšå¯èœãªããŒã«ãè©äŸ¡ããŸããåºæ¬çãªã³ã³ããŒãã³ãã®çæã«ã¯ã·ã³ãã«ãªããŒã«ã§ååãããããŸããããè€éãªã¹ãã£ãã©ãŒã«ãã£ã³ã°ã«ã¯ããã匷åãªãã¬ãŒã ã¯ãŒã¯ãå¿ èŠã«ãªãå ŽåããããŸãã
8. 詊éšéçšãšå埩
ã³ãŒãçæã·ã¹ãã ãçµç¹å šäœãŸãã¯å€§èŠæš¡ãªãããžã§ã¯ãã«å±éããåã«ãå°èŠæš¡ãªããŒã ãŸãã¯ç¹å®ã®æ©èœã察象ãšãã詊éšéçšããã°ã©ã ãæ€èšããŠãã ãããå®éã®äœ¿çšç¶æ³ã«åºã¥ããŠãã£ãŒãããã¯ãåéãããã³ãã¬ãŒããšããã»ã¹ãå埩ããŸãã
課é¡ãšèæ ®äºé
ãã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæã«ã¯å€§ããªå©ç¹ããããŸãããæœåšçãªèª²é¡ãèªèããããšãéèŠã§ãã
- é床ã®äŸåãšæœè±¡åã®æŒãïŒãã³ãã¬ãŒããé©åã«èšèšãããŠããªãå Žåãéçºè ã¯ãã³ãã¬ãŒãã«é床ã«äŸåããããã«ãªããçæãããæ§é ããéžè±ããå¿ èŠãããå Žåã«èŠåŽããå¯èœæ§ããããŸããããã«ããããã³ãã¬ãŒãã®åºç€ãšãªãè€éããæããã«ãªããåé¡ãšãªããæœè±¡åã®æŒããã«ã€ãªããå¯èœæ§ããããŸãã
- ãã³ãã¬ãŒãã®è€éãïŒæŽç·Žããããã³ãã¬ãŒãã®äœæãšä¿å®ã¯ãããèªäœãè€éãªéçºã¿ã¹ã¯ã«ãªããç¬èªã®ã¹ãã«ãšããŒã«ã»ãããå¿ èŠã«ãªããŸãã
- ããŒã«ãªãŒããŒãããïŒæ°ããããŒã«ãšã¯ãŒã¯ãããŒã®å°å ¥ã«ã¯ããã¬ãŒãã³ã°ãšé©å¿ãå¿ èŠã§ãããæåã¯äžéšã®ããŒã ã¡ã³ããŒã®ããŒã¹ãé ããªãå¯èœæ§ããããŸãã
- ã«ã¹ã¿ãã€ãºã®å¶éïŒäžéšã®ãã³ãã¬ãŒãã¯éåžžã«å³æ Œã§ãããããæåç·šéã«é Œãããšãªããåºæã®èŠä»¶ã«åãããŠçæãããã³ãŒããã«ã¹ã¿ãã€ãºããããšãå°é£ã«ãªãå ŽåããããŸããããã¯çæã®ç®çãç¡å¹ã«ããŸãã
- çæãããã³ãŒãã®ãããã°ïŒèªåçã«çæãããã³ãŒãå ã®åé¡ã®ãããã°ã¯ãç¹ã«çæããã»ã¹èªäœãè€éãªå Žåãææžãã®ã³ãŒãã®ãããã°ãããé£ããå ŽåããããŸãã
ã°ããŒãã«ããŒã ã®èæ ®äºé
åœéçãªéçºããŒã ã«ãšã£ãŠããã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæã¯ç¹ã«æçã§ãããç¹å®ã®èæ ®äºé ãå°å ¥ãããŸãã
- èšèªãšããŒã«ãªãŒãŒã·ã§ã³ïŒç¿»èš³ãããæååã®ãã¬ãŒã¹ãã«ããŒããã±ãŒã«åºæã®ãã©ãŒããããªã©ããã³ãã¬ãŒããåœéåïŒi18nïŒããã³ããŒã«ãªãŒãŒã·ã§ã³ïŒl10nïŒã®èŠä»¶ã«å¯Ÿå¿ã§ããããšã確èªããŸãã
- ã¿ã€ã ãŸãŒã³ãšã³ã©ãã¬ãŒã·ã§ã³ïŒäžå åãããããŒãžã§ã³ç®¡çããããã³ãã¬ãŒãã¯ãããŸããŸãªã¿ã€ã ãŸãŒã³éã§ã®äžè²«ããéçºãä¿é²ããŸããæç¢ºãªããã¥ã¡ã³ãã«ãããããŸããŸãªå°åã®éçºè ãçæãããã³ãŒããç°¡åã«çè§£ããŠäœ¿çšã§ããããã«ãªããŸãã
- æåçãªãã¥ã¢ã³ã¹ïŒã³ãŒãçæã¯äžè¬çã«æè¡çã§ããããã³ãã¬ãŒãå ãŸãã¯ãã®äœ¿çšãã¬ã€ãããããã«äœ¿çšãããäŸãŸãã¯ããã¥ã¡ã³ããæåçé æ ®ããããå æ¬çã§ããããšã確èªããŸãã
- ããŒã«ã®ã¢ã¯ã»ã·ããªãã£ïŒéžæããã³ãŒãçæããŒã«ããããŸããŸãªå°åã®ããŒã ã䜿çšããéçºç°å¢ãšäºææ§ããããã¢ã¯ã»ã¹å¯èœã§ããããšã確èªããŸãã
çµè«
ããã³ããšã³ãã³ãŒãçæãç¹ã«ãã³ãã¬ãŒãããŒã¹ã®éçºã¯ãéçºè ã®çç£æ§ãåäžãããã³ãŒãã®å質ã確ä¿ããææ°ã®Webã¢ããªã±ãŒã·ã§ã³ã®é ä¿¡ãå éããããã®åŒ·åãªæŠç¥ã§ããå埩çãªã¿ã¹ã¯ãèªååããäžè²«æ§ã培åºããããšã§ãããŒã ã¯ã€ãããŒã·ã§ã³ãšçã«åœ±é¿åã®ãããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ã®åµåºã«åãæ³šãããšãã§ããŸãã
ãœãããŠã§ã¢éçºã®ç¶æ³ãé²åãç¶ããã«ã€ããŠããããã®èªååæè¡ãæ¡çšããããšã¯ãç«¶äºåãç¶æããç¹ã«ãŸãšãŸãã®ãã髿§èœãªéçºç°å¢ãç®æãã°ããŒãã«ããŒã ã«ãšã£ãŠãé«å質ã®è£œåãå¹ççã«æäŸããããã«ãŸããŸãéèŠã«ãªããŸããé©åã«äœæããããã³ãã¬ãŒããšå ç¢ãªçæããã»ã¹ãžã®æè³ã¯ãããã³ããšã³ãéçºã®å°æ¥ã®å¹çæ§ãšã¹ã±ãŒã©ããªãã£ãžã®æè³ã§ãã
å®è·µçãªæŽå¯ïŒ
- çŸåšã®ãããžã§ã¯ãã§å埩çãªã³ãŒããã¿ãŒã³ãç¹å®ããŸãã
- YeomanãPlopãHygenãªã©ã®ããŒã«ã調ã¹ãŠãã³ãŒãçæã詊ããŠã¿ãŠãã ããã
- æãäžè¬çãªUIã³ã³ããŒãã³ããŸãã¯å®åæ§é ã®ãã³ãã¬ãŒããäœæããããšããå§ããŸãã
- ãã³ãã¬ãŒãã培åºçã«ææžåããããŒã å šäœãã¢ã¯ã»ã¹ã§ããããã«ããŸãã
- ããŒã ã®æšæºçãªéçºã¯ãŒã¯ãããŒã«ã³ãŒãçæãçµ±åããŸãã
ãã³ãã¬ãŒãããŒã¹ã®ã³ãŒãçæãæŠç¥çã«å®è£ ããããšã§ãããã³ããšã³ãéçºã©ã€ããµã€ã¯ã«ãå€§å¹ ã«æ¹åããããŒã ãããåªãããœãããŠã§ã¢ãããéãæ§ç¯ã§ããããã«ãªããŸãã