ãã®èšäºã¯å€ããªã£ãŠããŸãã çŸåšã®ããŒãžã§ã³å±¥æŽãåç
§ããŠãã ãããïŒä»¥åã®èšäºã¯ãã¹ãŠçŸåšã®ç¶æ
ã«æŽæ°ãããŸããïŒ
ãªããžããªãµã€ãïŒããã¥ã¡ã³ãããããŸãïŒ ã¿ãªããããã«ã¡ã¯ã ãããªã§ãŒã·ã«ã«é¢ããäžé£ã®èšäºãæåŸã«å
¬éãããŠãã5ãæãçµéããŸããã ãã以æ¥ãå°æ°ã®ãšã©ãŒãä¿®æ£ãããã³ã¡ã³ãã®åœ±é¿äžã§ãããžã§ã¯ãã
Shoojuã®ã¹ãã³ãµãŒãèŠã€ããããŽãšéåžžã®ããŒãã¹ãã©ãã以å€ã®Webãµã€ããåãåã£ããªã©ãããã€ãã®äŸ¿å©ãªæ©èœãç»å ŽããŸããã
ãããªã§ãŒã·ã«ã¯ãããŒã¿ã®éèŠæ§ãå€èŠ³ãæ¯é
ããæ±çšãã¬ãŒã ã¯ãŒã¯ã§ãããããŒã¿ãæŽæ°ããããšã€ã³ã¿ãŒãã§ã€ã¹ãèªåçã«æŽæ°ãããããšãæãåºãããŠãã ãããMatryoshkaã䜿çšãããšãããŒã¿ãšãã¬ãŒã³ããŒã·ã§ã³ã®ãããªãåæãå¿é
ããããšãªããããŒã¿ãšãã¬ãŒã³ããŒã·ã§ã³èŠçŽ ïŒãªããžã§ã¯ãããããã£ãå
¥åãã£ãŒã«ãã®å€ãªã©ïŒãç°¡åã«é¢é£ä»ããããšãã§ããŸãã ããšãã°ãæãåçŽãªãã€ã³ãã£ã³ã°ã¯æ¬¡ã®ããã«ãªããŸãã
<select class="my-select"> <option>1</option> <option>2</option> <option>3</option> </select>
ã€ã³ã¹ã¿ã³ã¹ãäœæããŸãã
var mk = new Matreshka();
xããããã£ã
.my-select
èŠçŽ ã«
.my-select
ã
mk.bindElement( 'x', '.my-select' );
ããŒã¿ãå€æŽãã
mk.x = 2;
ããããã£xã«ç°ãªãå€ãå²ãåœãŠãåŸãããã«å¿ããŠèŠçŽ ã®ç¶æ
ãå€åããŸãã
ã©ã€ãäŸãã芧ãã ããå
¥ãå人圢ã®ãã1ã€ã®éèŠãªæ©èœã¯ãã€ãã³ãïŒã«ã¹ã¿ã ã€ãã³ããå«ãïŒã§ãã ããšãã°ããããªã§ãŒã·ã«ã¯ããããã£ã®å€ã®å€åããã£ããã§ããŸãã
mk.on( 'change:x', function( evt ) { alert( 'x ' + evt.value ); });
ã³ãŒãã¯
"x "
ãåºåããŸãã
mk.x = '';
ãããããã³ãã®ä»ã®æ©èœã®è©³çŽ°ã«ã€ããŠã¯ãäžèšã®ãªã³ã¯ãåç
§ããŠãã ããã
èšäºã®ãã¶ã€ã³ã«ã€ããŠå°ãjsdocæ§æã䜿çšããŠã¡ãœãããšããããã£ã瀺ããŸããç¹ã«ãã©ãã£ã¹ïŒïŒïŒã¯ãããšãã°MK#addDependence
ã¯ã MK#addDependence
ã®ã€ã³ã¹ã¿ã³ã¹ã§ããaddDependence
ã¡ãœããã«ã€ããŠèª¬æããŠããããšãæå³ããŸãã
æããããã
ãã®æãã¯ãŒã«ãªæ¹æ³ã䜿çšãããšãäžéšã®ããŒã¿ãä»ã®ããŒã¿ã«äŸåããããšã確èªã§ããŸãã æåã®åŒæ°ã¯äŸåããããã£ã®ããŒã2çªç®ã¯ããããã£ãäŸåããããŒã®é
åïŒãŸãã¯ã¹ããŒã¹ã§åæãããããŒãæã€æååïŒã3çªç®ã¯ããããã£ã®æ°ããå€ãè¿ããã³ãã©ãŒé¢æ°ã§ãã ããã¯ãããããã£ãååŸãããã³ã«getterãåŒã³åºãããããããã£ãäŸåããããŒã¿ãå€æŽãããšãã«ã
addDependence
ãããããã£ã®å€ãäºåã«èšç®ãããšããéããããã²ãã¿ãŒã®äžçš®ã®çœ®æã§ãã æ¯èŒçéãèšç®ã¯ã³ãŒãã®ããã©ãŒãã³ã¹ã«å€§ããªåœ±é¿ãäžããå¯èœæ§ããããããã²ãã¿ãŒãæ
éã«äœ¿çšããå¿
èŠããããŸãã ãªãœãŒã¹ã®æ¶è²»ãšãã芳ç¹ããèŠããšããäŸåé¢ä¿ãã¯ããŒã¿å€æŽã€ãã³ãã®éåžžã®åŠçãšéãã¯ãªããå®éããããã«å¯Ÿããæ§æäžã®ç ç³ã§ãã ããã«ããã®ã¡ãœããã¯èªå·±ææžåã³ãŒãã«åãããã1ã€ã®ã¹ãããã§ãã
ããããã£ãŒ
f
åžžã«ããããã£ãŒ
a, b, c, d, e
ã®åèšã«ãªãå¿
èŠããããšããŸãããã
ããã¯ãçŽç²ãªã€ãã³ãã«åºã¥ããã³ãŒãã®ããã§ãã
this.on( 'change:a change:b change:c change:d change:e', function() { this.f = this.a + this.b + this.c + this.d + this.e; });
ããããããšæ¯èŒããŠãã ããïŒ
this.addDependence( 'f', 'abcd e', function() { return this.a + this.b + this.c + this.d + this.e; });
ãŸãã¯ããã§ãïŒ
this.addDependence( 'f', 'abcd e', function( a, b, c, d, e ) { return a + b + c + d + e; });
ãŸã ããžã§ã¹ãã£ãå°ãªãããå¿
èŠããããŸãïŒ 'change:'
ãããŒãããå¿
èŠã¯ãããŸããïŒ
第äºã« ãã¡ãœãããšåŒæ°ã®ååã«ããã察å¿ããã³ãŒãè¡ãäœæãããçç±ãæ確ã«ç解ããŸãã 人éã®èšèªã«ç¿»èš³ãããšãæåã®æ¹æ³ã¯ã a, b, c, d, e
ã®ããããã£ãå€æŽãããšãa, b, c, d, e
äœãããããšããã2çªç®ã®æ¹æ³ã¯ãããããã£f
ããããã£a, b, c, d, e
ãžã®äŸåæ§ãè¿œå ããã ãã éããæããŸããïŒ
第äžã« ãä»ã®ããããã£ãäŸåããããããã£ã®1ã€ãsilent
ãã©ã°ã§å€æŽãããå Žåãæåã®ãªãã·ã§ã³ã¯æ©èœããŸããã
ããšãã°ãå¢çç·ãèšç®ããã¿ã¹ã¯ããããŸãã
ãªãã·ã§ã³1ãã€ãã³ãæïŒ
this.on( 'change:a change:b', function() { this.p = ( this.a + this.b ) * 2; });
äŸåé¢ä¿ã䜿çšãããªãã·ã§ã³2ïŒ
ä»ãç§ãã¡ãåŒã³åºãå ŽåïŒ
this.set({ a: 2, b: 3 }, { silent: true });
...ãã®åŸãæåã®ããªã¢ã³ãã§ã¯p
ã¯å€åããã2çªç®ã§ã¯å€åããŸãã
p
å€æŽã§ã€ãã³ããã³ãã©ãŒããã³ã°ããã p
ãsilent
ãã©ã°ã®å€æŽã«äŸåããããããã£ã®1ã€ããã³ã°ãããå Žåãäºæ³ã©ãããå€æŽãã³ãã©ãŒp
ã¯åŒã³åºãããªãããšã«æ³šæããŠãã ããã
this.on( 'change:p', function() { } ); this.set( 'a', 12, { silent: true });
次ã®ããŒãžã§ã³ã§ã¯ãä»ã®ã¯ã©ã¹ã«ããããŒã¿ãžã®ããããã£ã®äŸåé¢ä¿ãè¿œå ããäºå®ã§ãïŒããŒã¿ãå€èŠ³ãæ¯é
ããã¢ããªã±ãŒã·ã§ã³ã®äžè¬çãªã¿ã¹ã¯ïŒã ããã¯æ¢ã«å®è£
ãããŠããŸãããèšèªæ§æã®å¶éã«ããææžåãããŠããŸããã ä»ã®ã¯ã©ã¹ãžã®äŸåé¢ä¿ã¯æ¬¡ã®ããã«ãªããŸãã
this.addDependence( 'a', [ instance1, 'bc d', instance2, 'ef g', this, 'hij' ], function() { });
2çªç®ã®åŒæ°ã®å¥æ°ã®é
åèŠçŽ ãã€ã³ã¹ã¿ã³ã¹ã§ããå Žåãå¶æ°ã®èŠçŽ ã¯ããŒã®ãªã¹ãã§ãã å
·äœçã«èŠããŸãããä»ã®ãªãã·ã§ã³ãããã°å¬ããã§ãã
äŸã®ããããŒãžã§ãã¡ãœããliveãèŠãããšãã§ããŸãã
Rendolã®ã³ã¡ã³ãã«é¢ããŠïŒãããã³ã°ã¯äŸåé¢ä¿ã䜿çšããŠå®è£
ã§ããŸãã
ã¡ãã£ãšãŒã¿ãŒïŒä»²ä»è
ïŒ
å€ãã®å ŽåãããŒã¿ã®æ€èšŒãšå€æã®ã¿ã¹ã¯ãå«ãŸããŸãã ã¯ã©ã¹ã«ããããã£ããããšããŸããããããã£ã¯åžžã«æååã§ãããä»ã«ã¯äœããããŸããã æšæºããŒã«ã䜿çšããŠãã®åé¡ã解決ããŠã¿ãŸãããã
ããã§äœãèµ·ãã£ãŠããã®ãç解ããŠããŸããïŒ æåã®ãã³ãã©ãŒã¯a
ãæååã«å€æa
ãæåŸã®2ã€ã®ãã³ãã©ãŒã¯a
æååãã©ããã匷å¶çã«ãã§ãã¯a
ãŸããã³ã³ããŒã¿ãŒãã³ãã©ãŒã¯ãã¹ãŠã®ãã³ãã©ãŒïŒèªèº«ãå«ãïŒãåã³éå§ããããã§ãã beforechange:%%
event beforechange:%%
ãããªè§£æ±ºçãæ±ããŠbeforechange:%%
ããã¬ãŒã ã¯ãŒã¯ã«æ°ããæŠå¿µãäžéäœããå°å
¥ããããšã決å®ãããŸããã
ã¡ãã£ãšãŒã¿ãŒïŒãŸãã¯ã¡ãã£ãšãŒã¿ãŒïŒã¯ããã®ããããã£ãŒã®å€æŽã«é¢é£ããã€ãã³ããããªã¬ãŒãããåã«ãããããã£ãŒã®å€ãå€æŽããŸãã
MK#setMediator
ã®æ§æã¯åçŽã§ããæåã®åŒæ°ã¯ã¡ãã£ãšãŒã¿ãŒãèšå®ããããŒã2çªç®ã®åŒæ°ã¯ããããã£ã®æ°ããå€ãè¿ãé¢æ°ã§ãã 代æ¿æ§æïŒã¯ã©ã¹ã§è€æ°ã®ã¡ãã£ãšãŒã¿ãŒãäžåºŠã«ãã³ã°ã¢ããããå Žåãã¡ãã£ãšãŒã¿ãŒããŒãªããžã§ã¯ããã±ãŒã¹ã®ã¡ãœããã«æž¡ãããŸãã
ããšãã°ãããããã£a
ã¯åžžã«æååã§ãããããã£b
ã¯åžžã«æŽæ°ïŒãŸãã¯NaN
ïŒã§ãªããã°ãªããŸãã
this.setMediator( 'a', function( value ) { return String( value ); }); this.setMediator( 'b', function( value ) { return parseInt( value ); });
ãããŠãJavaScriptãããç¥ã£ãŠãã人ã®ããã«ïŒ
this.setMediator( 'a', String ); this.setMediator( 'b', parseInt );
ã¡ãã£ãšãŒã¿ãŒã¯ããã®ãããªåçŽãªå¯èœæ§ã«éå®ãããŸããã èšç®ã®å®è¡ãçŠæ¢ãããã®ã¯ãããŸããããã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹ãæãªããªãããã«æ³šæããŠãã ããã
ãã®æ¹æ³ã¯ããµãŒããŒãç¹å®ã®ã¿ã€ãã®å€ãåãå
¥ããå Žåãå«ããéåžžã«äŸ¿å©ã§ã¯ãŒã«ã§ãã ã¡ãã£ãšãŒã¿ãŒã¯1ã€ã ãã§ãã åãããããã£ã§ã®æ¬¡ã®MK#setMediator
ã¯ãå€ãããã¯ããããã¯ããŸãã ãäžéããåé€ããããã«ãé¢æ°ã®ä»£ããã«null
ãæž¡ãããšãã§ããŸãã
äŸã®ããããŒãžããå®éã®äŸãèŠãŠã¿ãŸããã ã
mk.setMediator({ percentageValue: function( v ) { return v > 100 ? 100 : v < 0 ? 0 : v; }, stringValue: String, integerValue: parseInt });
3ã€ã®ããããã£ã«ããã¯ãèšå®ããŸããã 1ã€ç®ã¯ããŒã»ã³ãããããã£ã§ãïŒããããã£ã®å€ã¯0ãã100ãŸã§ã§ããã®ç¯å²ã®å¢çãè¶
ãããã®ã¯èªåçã«æå¹ãªå€ã«å€æãããŸãïŒ0æªæºã®å Žåãå€ã¯0ã«ãªãã100ãè¶
ããå Žåãå€ã¯100ã«ãªããŸãïŒã 2çªç®ã®å€ã¯æååã§ããããããã£ã¯åžžã«æååã§ãªããã°ãªããŸããã 3çªç®ã¯åžžã«æŽæ°ïŒãŸãã¯NaN
ïŒã§ãªããã°ãªããŸããã ã¢ã€ãã¢ãéçºããã«ã¯ãåžžã«çãŸãã¯åœã®ããããã£ãäœæããåžžã«äœããã®ã¯ã©ã¹ã®ã€ã³ã¹ã¿ã³ã¹ã«ãªãããããã£ãäœæããŸã...
å¥ã®çš®é¡ã®ã¡ãã£ãšãŒã¿ãŒããããŸãïŒé
åèŠçŽ ã®ã¡ãã£ãšãŒã¿ãŒã§ãã ãã®ãããªã¡ãã£ãšãŒã¿ãŒãã€ã³ã¹ããŒã«ãããšãè¿œå ãããåèŠçŽ ãåžæã©ããã«å€æãããŸãã ããã¥ã¡ã³ãã®äŸãã芧ãã ããã
var mkArray = new MK.Array( 1, 2, 3, 4, 5 ); mkArray.setItemMediator( function( value ) { return String( value ); }); mkArray.push( 6, 7 ); mkArray.unshift( true, {} );
console.log( mkArray.toJSON() );
ããã«ãããåä»ãé
åãã€ãŸãæååã®é
åãäœæãããŸãã ã¯ãããã¡ããããã®ãããªåä»ãé
åã¯ãçµã¿èŸŒã¿åä»ãé
åãšããã©ãŒãã³ã¹ãããã«ç°ãªããŸãã ããããããŒã¿ãæ€èšŒããã³å€æããæ©èœã«ã¯éçããããŸããã
é
åèŠçŽ ã®ã¡ãã£ãšãŒã¿ãŒãã¯ã©ã¹å
šäœã§å¯äžã®ãã®ã§ããããšãå¿ããªãã§ãã ããã ãŸããã¡ãã£ãšãŒã¿ãnull
èšå®ããããšã§åé€ã§ãnull
ã
mkArray.setItemMediator( null );
ãšããã§ãäžèšã®äŸã¯äžçŽããã°ã©ãåãã«ä¿®æ£ã§ããŸãã
mkArray.setItemMediator( String );
ãã£ããã
ãå€æ°ã®ã¢ããªã±ãŒã·ã§ã³ã«ããã
èšäºã®æåã®ã·ãªãŒãºã®çºè¡åŸãhabrayuzersã¯ãããªã§ãŒã·ã«ã®ããã€ãã®æ©èœãæ¹å€ããŸããã æ¹å€ã¯ååã«æ ¹æ ããããç©è°ãéžãåé¡ãæ€èšããŠä¿®æ£ããããšã決å®ãããŸããã ãããã®ããã€ãã次ã«ç€ºããŸãã
1. MK.ArrayïŒpopããã³MK.ArrayïŒshiftã¯ããselfãã§ã¯ãªããåé€ãããã¢ã€ãã ãè¿ããŸãã Starfall ïŒ èšäºãžã®ã³ã¡ã³ã ã winbackgo ïŒ èšäºãžã®ã³ã¡ã³ã
2. input[type="text"]
ããã³'keyup'
ããã©ã«ãã®ãã€ã³ããŒã¯ã 'keyup'
ã ãã§ãªã'paste'
ã€ãã³ãããªãã¹ã³ããããã«ãªããŸããã safron ïŒ èšäºãžã®ã³ã¡ã³ã
3. input[type="checkbox"]
ããã³input[type="radio"]
ã®ããã©ã«ãã®ãã€ã³ããŒã¯ã 'keyup'
ã€ãã³ãããªãã¹ã³ããããã«ãªããŸããã ããã¯ããããã®èŠçŽ ã«ããŒã¿ããã€ã³ããããšãã«ããŒããŒããããããã®èŠçŽ ãæäœã§ããããšãæå³ããŸãïŒåãã³ã¡ã³ãïŒã
ãã©ã©ã€ã«
ããã«ã jQuery
ãžã®åŒ·ãäŸåé¢ä¿ãåé€ããããšã決å®ãããŸããã ç§ã®æèŠã§ã¯ã jQuery
ã¯çŽ æŽãããã©ã€ãã©ãªã§ãããæ°ãããã©ãŠã¶ãŒã§ã¯é¢é£æ§ã倱ããŸãã çŸåšãããŒãžã«jQuery
ãªãå ŽåããBalalaikaããšåŒã°ããããã©ã€ãã©ãªã«çœ®ãæããããŸãïŒæ³šïŒããã§ãªãå Žåã®ã¿jQuery
æ¥ç¶ãããŠããå Žåã jQuery
ã¯åŒãç¶ã䜿çšãããŸãïŒã
balalaikaã¯Array.prototype
ç¶æ¿ãããããéçºè
ã¯é
åã«å«ãŸãããã¹ãŠã®ã¡ãœããã«å ããŠãã¯ã©ã¹ïŒ addClass
ã removeClass
ã hasClass
ïŒãã€ãã³ãïŒ on
ã off
ïŒãHTML解æïŒ parseHTML
ïŒãªã©ãparseHTML
jQuery
äºæã¡ãœããã䜿çšã§ããŸãã
BalalaikaãçŽæ¥äœ¿çšããã«ã¯ãã°ããŒãã«å€æ°$ bã䜿çšãããŸãã
$b( 'div' ).forEach( function(){ } ); $b( '.blah-blah', context ).is( 'div' ); $b( 'input[type="text"]' ).on( 'keydown', handler );
ïŒãã©ã©ã€ã«ã«é¢ããå¥ã®æçš¿ãæžãäºå®ã§ãïŒ
banzalik ïŒ é¡ãã蟌ããŠã³ã¡ã³ããã
jMas ïŒ å¥ã®ã³ã¡ã³ã
ãã®ä»ã®é©æ°
this
ãã€ã³ããããã»ã¬ã¯ã¿ãŒå
ã®ã»ã¬ã¯ã¿ãŒã«äžèŽããæåã®èŠçŽ ãéžæãthis
ïŒããŒ"__this__"
ã以åã®èšäºãåç
§ïŒã ãã®ã¡ãœããã¯ãèŠçŽ ã®ã³ã¬ã¯ã·ã§ã³ã§ã¯ãªããåã
ã®èŠçŽ ã§ã®äœæ¥ãç°¡çŽ åããããã«äœæãããŸããã
this.select( '.blah-blah' );
this
ãžã®ãã€ã³ãå
ã§ã»ã¬ã¯ã¿ãŒã«äžèŽãããã¹ãŠã®èŠçŽ ãéžæããŸãã $
ïŒãã«èšå·ïŒã¡ãœãããšåãã§ãã MK#selectAll
ãã¡ãœããã®ã»ãããå®äºããããMK#selectAll
äœæãããŸããããselectãã¡ãœããïŒ MK#select
ïŒãããå Žåããselect allãã¡ãœãããå¿
èŠã§ãã
this.selectAll( '.blah-blah' );
æå®ãããã€ã³ããã¯ã¹ãæã€ã¢ã€ãã ãåé€ããŠè¿ããŸãã
var x = this.pull( 3 );
ããã¯ã splice
äžã®æ§æç³ã§ãã
var x = this.splice( 3, 1 )[ 0 ];
察å¿ããã¯ã©ã¹ã®ã€ã³ã¹ã¿ã³ã¹ã§åžžã«true
ã§ããããããã£ã
var mkObject = new MK.Object(); alert( mkObject.isMK && mkObject.isMKObject );
ä¿®æ£
ããã«ãããã€ãã®ãã°ãä¿®æ£ãããŸããã ä¿®æ£ã®ãªã¹ãã¯æ¬¡ã®ãšããã§ãã
ååãå€æŽãããã¡ãœãããšããããã£
semver.orgã®æšå¥šäºé
ã«åŸã£ãŠãå»æ¢ãããã¡ãœãããšããããã£ã¯ãªãªãŒã¹1.0ãŸã§åé€ãããŸããããèŠåãšæ°ããã¡ãœããã䜿çšããèŠæ±ã¯ã³ã³ãœãŒã«ã«è¡šç€ºãããŸãã
ã¹ããŒãã¢ã¬ã€
MK.Array
ãã©ã°ã€ã³ã¯MK.Array
ã§èšåãããŠMK.DOMArray
ã MK.Array
ã«é¢ããèšäºã§èšåãããŠãMK.Array
ã ã€ãŸããã泚ç®ãéãããGIFãåæ ããæ©èœã¯ããã®ãŸãŸã§æ©èœããŠããŸããã MK.DOMArray
ãã©ã°ã€ã³ã¯ãé
åãå€æŽïŒè¿œå ãåé€ã䞊ã¹æ¿ããªã©ïŒãããšèªåçã«DOMãå€æŽããããšãæãåºãããŠãã ããã
ãããªã§ãŒã·ã«ã®ãŠã§ããµã€ãã®äŸãã芧ãã ãã ã ã¹ããŒãã¢ã¬ã€ã®è©³çŽ°ãªèª¬æã¯ãå°ãåŸã§èšç»ãããŸãã
ããŒãããã
- 眮æå¯èœãª
Model
ããããã£ãå®è£
ããŸãïŒããã¯Backbone
ã®model
䌌ãŠããŸãïŒã ãã®æ©èœã¯ãé
åèŠçŽ ã®ã¡ãã£ãšãŒã¿ãŒäžã®æ§æç³è¡£ã§ãã - é
延åæåã çŸåšãç¶æ¿ãããšãã¯ãåžžã«
initMK
ã¡ãœãããåŒã³åºãå¿
èŠããããŸãã ã³ãŒã·ã£ã§ã¯ãããŸããã - ã€ãã³ããšã³ãžã³ãæžãæããŸãã ãããããDOM
EventTarget
ã€ã³ã¿ãŒãã§ãŒã¹ãEventTarget
ãšãªãã§ãããã MK#addDependence
ãæŽæ°ããŠãä»ã®ã¯ã©ã¹ã€ã³ã¹ã¿ã³ã¹ãžã®äŸåé¢ä¿ãäœæããŸãïŒäžèšãåç
§ïŒã- ãããã¡ã€ã€ã®ã³ãŒããæé©åããŸãã
- ãµã€ãäžã®æ£ããããã¹ãã ã芧ã®ãšããããµã€ãã¯è±èªã§ãããããã¹ãã«èª€ãããããŸãã ãšã©ãŒãããããã¹ããéžæããåŸãCtrl + Enterã®çµã¿åããã䜿çšããŠããšã©ãŒãä¿®æ£ããããšãã§ããŸãïŒèŠæ±ããŒã«ãäœæããªãããã«ïŒã ãšãŠãæè¬ããŸãã
ããŒãžã§ã³1.0ïŒçŽ1幎åŸã«äºå®ïŒã§ã¯ãæåã«å»æ¢ãããã¡ãœãããåé€ãã次ã«8çªç®ã®ãã³ããŒã®ãµããŒããåé€ããäºå®ã§ãã IE8ããµããŒããã人ãããªããã°ããã¹ãŠã®ã€ã³ã¿ãŒãããã®åç«ã¯å¹žãã«ãªããŸãã
çµè«ãšããŠ
ãããžã§ã¯ãã®åšãã®æãããªæ²é»ã«ããããããããããªã§ãŒã·ã«ã¯éçºäžã§ãã ãã¹ãŠã®æ©èœã¯åŸ¹åºçã«ãã¹ããããŠããã ãã§ãªããã©ã€ãã¢ããªã±ãŒã·ã§ã³ã§ãåäœããŸãã
Matryoshkaã®ãã1ã€ã®ç®æšã¯ããã¬ãŒã ã¯ãŒã¯ã䜿çšããéçºè
ããããŒã¿ã®ç¥ãã«ããã€ã³ã¿ãŒãã§ã€ã¹ãæ°ã«ããã«ãã¢ãã«ã§äœãèµ·ãã£ãŠããããå®å
šã«å¶åŸ¡ããããšã§ãã ããšãã°ããªããžã§ã¯ããšé
åã®ããªãŒã«ããŒã¿å€æŽã€ãã³ãã®ãããã¢ããã€ãã³ããå®è£
ããäºå®ã§ãããã¯éåžžã«ã¯ãŒã«ã§ãã ããã«-ãã£ãš...
ã¢ã¯ã»ãµïŒã²ãã¿ãŒãšã»ãã¿ãŒïŒã«åºã¥ããMatryoshkaã³ã¢ã«ãã£ãŠæäŸãããã¹ããŒã¹ã¯ãããã°ã©ããŒã®åµé æ§ã®ããã®æãåºãåéãæäŸããŸãã åæãã仲ä»è
ãšäŸåé¢ä¿ã®ã¢ã€ãã¢ã¯è¡šé¢ã«ãããŸãã å
¥åã§ã¯ã value
ããããã£ã¯åžžã«æååã§ãããããããã«é
眮ããªãããã«ã valueAsNumber
ããããã£valueAsNumber
åžžã«æååå€ã«äŸåããæ°å€ã§ã...
æçš¿ãæåŸãŸã§èªãã ïŒãŸãã¯ã¹ã¯ããŒã«ããŠãããŠïŒããããšãã ãã¹ãŠã®åã®å
ç·ã