æ»æç
ããã«ã¡ã¯ è€éãªWebã¢ããªã±ãŒã·ã§ã³ã®ã€ã³ã¿ãŒãã§ãŒã¹ã®éçºã«åœ¹ç«ã€èå³æ·±ãæ°ãããã¯ãããžãŒã«ã€ããŠå°ãã話ããããšæããŸãã
éå»æ°å¹Žéã§ãWebã¢ããªã±ãŒã·ã§ã³ã¯é©ãã»ã©éçºããã匷ã¿ãç²åŸããtraditionalæ
¢ãªåŸå
åŒã§ããåŸæ¥ã®ãã¹ã¯ãããã¢ããªã±ãŒã·ã§ã³ãã軜deçãªç¬ãæããªããªããŸããã ãããäœããããç§ãã¡ã®ç®ã®åã«ãWebã€ã³ã¿ãŒãã§ãŒã¹éçºããŒã«ã®åéã§å°ããªé©åœããããŸãããããã¯ãã€ã³ã¿ãŒãã§ãŒã¹éçºè
ãšãã®æè¬ãããŠãŒã¶ãŒã®äž¡æ¹ã®ç掻ã倧ãã«ä¿é²ããŸããã
ExtJã§è¡ããããã¹ã¯ãããã·ãã¥ã¬ãŒã·ã§ã³èæ¯
ããã°ã©ããŒã¯ããããããããã®è¥ãã§èãããç·ã«ãªãã女ã®åããããã«ãªããä»äºã楜ã«ãªã£ããšæ³£ãåºããªããåçš®ã®å¯äžã®å°é家ã§ãã å€ããå°ãªããçµéšè±å¯ãªã€ã³ã¿ãŒãã§ã€ã¹éçºè
ã¯ã2ã€ã®ç»é¢è§£å床ã3ã€ã®ãšã³ã³ãŒãã£ã³ã°ã4ã€ã®ç°ãªããã©ãŠã¶ã§ããŒãžã³ãŒãããããã°ããã¡ã¢ãªã1ã€ã ããšãã倢ã§å«ã³ç¶ããŠããŸãã
ç³ççŽ
ãã®ãããèãç·ã«ãªãã女ã®åãåªãããªããã¢ãã¿ãŒãåããªã£ããšããHTMLãCSSãããã³jscriptãŸãã¯vbscriptããéžæã§ãã匱ãã¹ã¯ãªããèšèªãããããŸããã§ããïŒãŸã£ãã圹ã«ç«ã¡ãŸããïŒã
ã¹ã©ã€ãã«ãŒã«ã§å°çãæãããšã¯é£ãããHTMLã䜿çšããŠå€ããå°ãªããè€éãªã€ã³ã¿ãŒãã§ã€ã¹ãæ§ç¯ããããšã¯å°é£ã§ãã æ®å¿µãªãããTim Berners-Leeã¯ã誰ããéè¡ã®ã¢ããªã±ãŒã·ã§ã³ãé»åã¡ãŒã«ã¯ã©ã€ã¢ã³ããéçºããããã«ããã¥ã¡ã³ãã®æ§é ã説æããããã«å®£èšåèšèªã䜿çšããããšãæ³å®ããŠããŸããã§ããã
äžéšã®åããèŠãã¯ãActiveXããã³Javaã¢ãã¬ããã䜿çšããããšããŸããïŒãã¢ããªã±ãŒã·ã§ã³ã¯å®è¡äžã§ããïŒãïŒããããã倧ããæåã¯ãããŸããã§ããã ãªããªãé£ãã話ã§ããã
äžäž
æéãçµã€ã«ã€ããŠãã¹ã¯ãªããèšèªã¯åŸã
ã«åãå¢ããDHTMLïŒãã€ãããã¯HTMLïŒãšããçšèªãããã®èªåœã«ãã£ãããšå®çããŸããã ããã«ãããããããŠã³ã¡ãã¥ãŒããªããã°å€§èŠæš¡ãªåçšãµã€ãã¯ã§ããŸããã§ããã dhtmlããŒãžãæŽç·ŽãããŠããã°ããã»ã©ããã©ãŠã¶ã«è¡šç€ºããããšãã«ãšã©ãŒãå¢ããŸããã èªã¿æžãã®ã§ããªãã³ãŒããè±å¯ã«ãããããå€ãã®ãµã€ãã¯åã«äœ¿çšããããšãäžå¯èœã§ããã å¹³åçãªéçºè
ã¯ãŸã äžé£ã®ãã©ãããã©ãŒã ã§äœæ¥ããéåœã«ããããããããç¬èªã®åé¡ãè¿œå ããŸããã
æ°ããæé
åæã®ãã¹ãŠã®äººã
ã®å€§ããªåã³ã«ãjscriptã¯vbscriptãæã¡è² ãããç§ãã¡ã®èªç±ã§æåããçµ±åãŠãŒãã£ãªãã£ã©ã€ãã©ãªãçŸãå§ããéçºããã»ã¹ã倧å¹
ã«ç°¡çŽ åããå€ããå°ãªããäºææ§ã®ããã³ãŒãã®äœæãå¯èœã«ããŸããã ããã«ãéçºè
ïŒãããŠéèŠãªã®ã¯é¡§å®¢ïŒã®é ã®äžã«ãã§ã«å®çããŠããAjaxã¯ãã€ã³ã¿ãŒãã§ãŒã¹éçºã®ã¢ãããŒããæ°žä¹
ã«å€ããŸããã
䞊è¡ããŠãæè¿ãŸã§ããã°ã©ããŒã®èª°ãçå£ã«åãæ¢ããŠããªãã£ãMacromediaãšãã®Flashã¯ãWebã¢ããªã±ãŒã·ã§ã³ãéçºããããã®ããã»ã©ããããããªãããŒã«ãæäŸãå§ããŸããã
ç§ãã¡ã®æ¥ã
ããã¯ãé»éæ代ãå°æ¥ãããšèšã£ãŠããããã§ã¯ãããŸããããç§ã¯ç¹°ãè¿ããŸããããªããã€ã³ã¿ãŒãããã¢ããªã±ãŒã·ã§ã³ã®éçºã«ãããŠå°ããªé©åœããã§ã«èµ·ãã£ãŠããŸãã ææ°ã®ãã¬ãŒã ã¯ãŒã¯ã«ãããWebã€ã³ã¿ãŒãã§ãŒã¹ããã°ã©ããŒã¯ãããŒããŒã¯ãªããããã¥ãŒã€ã³ã¬ã ããå®å®ãã±ããã補é ãã人ã®ããã«ã¯æããªããªããŸãã
ããã¯ããŒã¹-匷åãªããã«èŸ²æ°ãã©ãããã©ãŒã ã®åé¡
ãã©ãŠã¶ãé çã®å°çšè¬ã§ããçç±ïŒ
- HTMLã¯èŠçŽ ãæ£ç¢ºã«é
眮ããã®ã«æªã
Jscriptã¯ä»ã®è§£éããããã®ã®ããã«é
ããªããŸã
DOMãé
ããªããŸã
DOMã®ãªã¢ã«ã¿ã€ã å€æŽãéåžžã«é
ã
ç°ãªããã©ãŠã¶ãšOSéã®Jscriptã®äºææ§ã¯ãŸã äžååã§ã
ã³ãŒãã«å°ããªãšã©ãŒããããšãã¢ããªã±ãŒã·ã§ã³å
šäœãã¯ã©ãã·ã¥ããå¯èœæ§ããããŸãã
解決ç
ãã¹ãŠã®äººãšãã¹ãŠã®äººã®ããã®åäžã®ã¡ã€ã³äºæãŠããã¡ã€ããã©ãŠã¶ã®äœæã¯ãJade Emperorã®æ代ã®Celestial Empireã§ãå¯èœã§ãããç§ãã¡ã®çã£ãæ代ã«ã¯ããããå¿ããæ¹ãè¯ãã§ãããã ãããã£ãŠãè³¢æãªããã°ã©ããŒã¯å¯äžã®å¯èœãªåããããŸãã-圌ãã¯ãã©ãŠã¶ãŒãšéçºè
ã®éã«ã¬ã€ã€ãŒãäœæããŸããã
ãã®ãããªã¬ã€ã€ãŒã䜿çšãããšãdocument.allãŸãã¯document.layersãXMLHttpRequestãŸãã¯Microsoft.XMLHTTPãå®éã«äœ¿çšãããã©ããã¯é¢ä¿ãããŸãããå¿
èŠãªãã¹ãŠã®å€æã¯ãåå ããããšãªãèå°è£ã§å®è¡ãããŸãã
ããã¯ãFlexãExtJãGWTãBackBaseãããã³é«åºŠãªWebã¢ããªã±ãŒã·ã§ã³ãäœæããããã®ä»ã®ããã€ãã®çŸä»£çãªãã¬ãŒã ã¯ãŒã¯ã®äœæè
ãè¡ã£ãæ¹æ³ã§ãã
åé¡
ããããã¹ãŠã®åªããéçºæè¡ã¯ã倧ãã4ã€ã®ã¿ã€ãã«åé¡ã§ããŸããè¡šãåç
§ããŠãã ããã
ãªããžã§ã¯ãæåã³ãŒã Gwt Extjs
ã³ã³ãã€ã«æžã¿vs解éæžã¿
ã³ã³ãã€ã«ããããã¯ãããžãŒã¯ãã³ãŒããã³ã³ãã€ã«ïŒãµãã©ã€ãºïŒãããã€ããªå®è¡å¯èœãã¡ã€ã«ïŒFlexãSilverLightïŒãŸãã¯ãã¬ãŒã³HTML + JscriptïŒGWTïŒã«å€æããŸãã
éèš³è
ã¯ãéåžžã©ããããã©ãŠã¶ã䜿çšããŠJscriptãå®è¡ããŸãããæšæºDOMïŒExtJsã®Ext.ElementãPrototypeã®ElementïŒã®ä»£ããã«ãå¥ã®ã¬ãã«ã®æœè±¡åããªããžã§ã¯ãã¢ãã«ã«è¿œå ããŸãã
ãã¡ãããã³ã³ãã€ã©ãŒã¯è¯ãããšã§ãããããã«ã¯ããªãã®äŸ¡æ ŒããããŸãïŒã³ã³ãã€ã«ã¹ããŒãžãè¿œå ããããããéçºãµã€ã¯ã«ãé·ããªããŸã-ã³ã³ãã€ã«ããããã€ãå®è¡ãã³ã³ãã€ã«ããããã€ãå®è¡...ãããŠFlexã®å Žåããæ°ã«å
¥ãã®IDEã«ã¯ãActionScriptãµããŒããè¿œå ããå¿
èŠããããŸãïŒSilverLightãç§ãç解ããŠããããã«ã.NETãšçµ±åããGWTãšJavaãçµ±åããŸãïŒã
OOPãšå®£èšç
äžéšã®ãã¬ãŒã ã¯ãŒã¯ã¯å®£èšçãªXHTMLã®ãããªã³ãŒãã䜿çšããŠã€ã³ã¿ãŒãã§ã€ã¹ãæ§ç¯ããŸãïŒBackBaseïŒ <b:listGrid width="auto" height="100%" />
ïŒãä»ã®ãªããžã§ã¯ãæåã®ã³ãŒãã䜿çšããŸãïŒExtJsïŒ new Application.GridPanel(âŠ).add(new Application.Button(âŠ)
ïŒã
å人çã«ã¯ãOOPã¢ãããŒãã奜ã¿ãŸãã宣èšåã¢ãããŒãã§ã¯ãæšæºãŠã£ãžã§ããã®æ©èœãæ¡åŒµããããã«è¿œå ã®é宣èšåã³ãŒããèšè¿°ããå¿
èŠãããããã§ãã ããšãã°ãBackBaseã®ã³ãŒãã¹ããããã¯æ¬¡ã®ããã«ãªããŸãã
<e:handler event="click" type="text/javascript">
var oMask = document.getElementById("maskContainer");
oMask.style.zIndex = "3";
[...]
</e:handler>
ãã®ã¹ã¿ã€ã«ã«ã¯å©ç¹ããããŸã-HTMLãšã³ã³ãŒããŒïŒã¿ã°ïŒã¿ã°!!ïŒã«è¿ããç解ããããã§ãããæ®éã®ããã°ã©ããŒãæããããããšãã§ããŸãã
Ajax vsãã©ã°ã€ã³ããŒã¹
MSãšMacromediaïŒã€ãŸããAdobeã®ããïŒã®äººãã¡ã¯ãã³ã³ãã€ã«ãããã³ãŒãïŒFlexãSilverLightïŒãå®è¡ããä»®æ³ãã·ã³ãšããŠåäœãããã©ã°ã€ã³ããã©ãŠã¶ã«ã€ã³ã¹ããŒã«ããããšã«shããŠããŸããã ãã©ã°ã€ã³ã«ã¯ããŸã第äžã«ãå®è¡é床ãšããå€ãã®å©ç¹ããããŸãã 解éãããã³ãŒãã¯å®è¡å¯èœã³ãŒãã«è¿œãã€ããŸããã
ããã«ããã®ãã©ã°ã€ã³ã¯ããœãŒã¹ã³ãŒããã»ãšãã©å€æŽããããšãªããããŸããŸãªãã©ãããã©ãŒã ã«ç§»æ€ã§ããŸãã ã¢ããã¯ãã§ã«Flexéçºè
ãAIRã«ãã»ãŒæ¬ç©ã®ããã¹ã¯ãããã¢ããªã±ãŒã·ã§ã³ãæžãããšãå¯èœã«ãããã¯ãããžãŒãäœã£ãŠããŸãã
ãã ããæ¬ ç¹ãæããã§ã-ãã¹ãŠã®ãŠãŒã¶ãŒããã©ã°ã€ã³ãã€ã³ã¹ããŒã«ããæºåãã§ããŠããããã§ã¯ãªããå®æçã«æŽæ°ããããšããã§ããŸããã ããã«ãéçºè
ã§ããããªãã¯ããã©ã°ã€ã³ã®è£œé äŒç€Ÿã«ãã£ãããšçµã³ä»ããããŸãã æŽæ°ããã³ãµããŒããçµäºããå Žåãã¢ããªã±ãŒã·ã§ã³ãå床æžãæããå¿
èŠããããŸãã åŸæ¥ã®Jscriptãã¬ãŒã ã¯ãŒã¯ã®ã¡ãŒã«ãŒãåç£ããå Žåãã¢ããªã±ãŒã·ã§ã³ãèªåã§åäœç¶æ
ã«ç¶æããããšãã§ããŸãããã¹ãŠã®ã³ãŒããæã£ãŠããŸãã
ãã¬ãã¯ã¹-éåžžã«é«éã§ãããéåžžã«é¢åã§ã
æ°æ§ã¢ãã«
èšåããããã¹ãŠã®ãªããžã§ã¯ãæåæè¡ã¯ãã€ã³ã¿ãŒãã§ãŒã¹èªäœã®èšè¿°ã«å¯ŸããŠå€ããå°ãªããåãã¢ãããŒãã䜿çšããŸãã HTML / CSSã³ãŒãã¯ãäžé£ã®ãªããžã§ã¯ãã«åã£ãŠä»£ãããŸãã 代ããã«
<table âŠ>
My application
<table âŠ>
My application
<table âŠ>
My application
New Panel({ header: âMy applicationâ })
ãããªãã®ãæžããŠããŸãNew Panel({ header: âMy applicationâ })
<input type=âbuttonâ value=âMy Buttonâ ⊠/>
代ããã«<input type=âbuttonâ value=âMy Buttonâ ⊠/>
New Button( {label: âMy buttonâ, handler: Buttons.myButton.click} )
ãªã©ãªã©ã èå°è£ã§ã¯ãããããã³ãŒãã¯ãã¹ãŠåãHTML / CSSã«å€æãããŸãããã€ã³ã¿ãŒãã§ã€ã¹ã®æ瀺çãªæ§ç¯ã¯ãéåžžã®ãã¹ã¯ãããã¢ããªã±ãŒã·ã§ã³ã®éçºè
ã«éŠŽæã¿ã®ãã圢åŒã§è¡ãããŸãã
éžææ¹æ³
ã¯ããéçºã«æé©ãªãã¯ãããžãŒãéžæããæ¹æ³ã¯ïŒ æ£è§£ã¯ååšããŸããã ããªããäœã決å®ã ãã®ãããªèãã«ã€ããŠã¯ãå°ãªããšã次ã®åºæºãèæ
®ããããšããå§ãããŸãã
- ãã¯ãããžãŒãæäŸããæ°ããæ©äŒ
æ°ããéçºè
ã®ãã¬ãŒãã³ã°æéïŒãšã³ããªã®ãããå€ïŒ
çžå¯Ÿéçºé床
ã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹
éçºç°å¢ã§è¡ãããå€æŽ
è¿
éãªã¢ããªã±ãŒã·ã§ã³æ§ç¯ïŒRADïŒã®ããã®ããŒã«ã®å¯çšæ§
ãµãŒããŒã³ãŒããšçµ±åããæ©èœ
å
èš±
ã¡ãŒã«ãŒïŒãŸãã¯ãªãŒãã³ãœãŒã¹ã®å Žåã¯ããã¢ã®ããŒã ïŒã®è©å€ãšå¯¿åœ
æè¡ãµããŒã/ããã¢åããã©ãŒã©ã
ããã©ã«ãã§å©çšå¯èœãªã°ã©ãã£ãã¯ããŒãã®å質ïŒæ®å¿µãªããšã«ãããã€ãã®éåžžã«æ·±å»ãªãã¬ãŒã ã¯ãŒã¯ã«ã¯ãè¿œå ã®ãã¡ã€ã«åŠçãªãã§ã¯ããã®ãŸãŸã䜿çšã§ããªãç¡åãªããŒãã»ãããè£
åãããŠããŸãïŒ
ããã¥ã¡ã³ãã®å質
ããŒã«ãªãŒãŒã·ã§ã³ãšåœéå
æ¡åŒµæ§-ç¬èªã®ã³ã³ããŒãã³ããäœæããæ©èœ
...ãããŠããã«100äžã®èãã ã©ã®èŠçŽ ãããªãã«ãšã£ãŠéèŠã§ãäœããããããããšãã§ããããèªåã§æ±ºããŠãã ããã
ãããã«
Webã€ã³ã¿ãŒãã§ãŒã¹éçºè
ã®ç掻ã¯ãæè¿å€§å¹
ã«ç°¡çŽ åãããŸããã ExtJãGWTãFlexãSilverLightãBackBaseãããã³ãã®ä»ã®å€ãã®ææ°ã®éçºã¯ãã¢ããªã±ãŒã·ã§ã³ãã©ãããã©ãŒã ãšããŠã®ãã©ãŠã¶ãŒã®æ¬ ç¹ãäºå®äžäžåããŸãã æ¢è£œã®åªããæè¡ã䜿çšããè»èŒªãåçºæããªãã§ãã ããããã¹ãŠãããŸããããŸãã
PSãã®èšäºããã³ãã®ä»ã®èšäºã¯ããµã€ãemdin-here.ruã§èªãããšãã§ããŸãã