Slide 1

Slide 1 text

3BJMT 3FBDUͳ 41"αΠτͰͷ4&0

Slide 2

Slide 2 text

ࣗݾ঺հ w٢઒ਸྙ JEBEPSFDIJD  w Φ΢νʔϊऔక໾$50 w όοΫΤϯυ԰ w ࠃ಺େखϒϩάαʔϏε΍ϨγϐαʔϏεձࣾͷόοΫΤϯυ w ݩ.JDSPTFSWJDFT͓͡͞Μ w CVJMEFSTDPOͰΩʔϘʔυ೤͕ߴ·͍ͬͯΔ

Slide 3

Slide 3 text

41"4&0

Slide 4

Slide 4 text

41" 4&0΍Δલ w443͠ͱ͚͹͍͍ΜͰ͠ΐ w 443ͪ͠Ό͑͹ඇ41"αΠτͱಉ͡Α͏ͳ΋ΜͰ͠ΐ w Ͱ΋࠷ۙ͸+4ධՁͯ͘͠ΕΔΒ͍͠͠ෆཁ͔΋ w443ͷπʔϧ΋͍Ζ͍Ζ͋Γͦ͏ w IZQFSOPWBͱ͔/FYUKTͱ͔Α͘ฉ͘ʢҧ͍͸Α͘Θ͔͍ͬͯͳ͍ʣ wଞࣾͷߏ੒ࣄྫ͸ͪΒ΄Βݟ͔͚Δ w ͦΕࢀߟʹಋೖͰ͖ͦ͏

Slide 5

Slide 5 text

ݱࡏͷߏ੒ w3FBDU w 3FEVY 4BHB 3FBDU3PVUFS 3FBDU)FBE w %ZOBNJD*NQPSUͰ$PEF4QMJUUJOH w XFCQBDLFS w $43༻ͱ443༻ͰXFCQBDLDPOpH͸݁ߏΧελϜ͍ͯ͠Δ w3BJMT IZQFSOPWB

Slide 6

Slide 6 text

ͳΜ͔Ͳ͔͜Ͱݟͨ͜ͱ͋Δߏ੒ʁ

Slide 7

Slide 7 text

41" 4&0΍ͬͯΔ࠷த w443͠ͱ͚͹͍͍ͳΜͯ୭͕ݴͬͨΜͩʂʂʂ w ؾΛ͚ͭΔ͜ͱ͕ඇ41"ͱ݁ߏҧ͏ w ͦ΋ͦ΋443͕݁ߏ͍ͨ΁Μ wߏ੒͕Ұͭҧ͚ͬͨͩͰམͱ͕݀͠େྔʹ͋Δ w νϡʔτϦΞϧΛಈ͔͢ͷ͸؆୯ w ଞࣾࣄྫ͸ϗϯτʹࢀߟఔ౓ w ར༻͍ͯ͠Δ֤πʔϧΛͪΌΜͱཧղ͢Δඞཁ͕͋Δ

Slide 8

Slide 8 text

࠷ऴߏ੒͚ͩ·ͱΊΔͱ ࣦഊͷྺ࢙͕఻ΘΒͳ͍ͷͰ ࣌ܥྻͰ͓఻͑͠·͢

Slide 9

Slide 9 text

No content

Slide 10

Slide 10 text

Φ΢νʔϊ wෆಈ࢈ʹؔ͢ΔαʔϏε w ෆಈ࢈ݕࡧϙʔλϧ w ϥΠϑελΠϧϝσΟΞ w ෆಈ࢈৘ใπʔϧ

Slide 11

Slide 11 text

ܦҢ wαΠτϦχϡʔΞϧͰ3FBDU 3BJMTʹͨ͠ w ࠷ॳ͸OPJOEFYͰݶఆతͳެ։Λ͍ͯͨ͠ wશମతʹ੾Γସ͑ΔલʹΠϯσοΫε͍ͤͯ͜͞͏ w ࠷ॳͷΰʔϧ͸͋͘·ͰΠϯσοΫεͤ͞Δ͜ͱ w ͜ͷஈ֊ͰݕࡧॱҐΛ͋͛Α͏ͱ·Ͱ͸ࢥ͍ͬͯͳ͔ͬͨ w ద੾ͳλάΛઃఆ͢ΔͳͲͯ͠OPJOEFYΛ֎ͨ͠ w +4ධՁ͞ΕΔΒ͍͠ͷͰ443ແ͠Ͱ༷ࢠΛݟΑ͏

Slide 12

Slide 12 text

ΠϯσοΫε͞Εͳ͍ wݕࡧॱҐӠʑͰ͸ͳͦ͘΋ͦ΋ΠϯσοΫε ͯ͘͠Εͳ͍ w αΠτϚοϓૹ৴ͳͲ͸࣮ࢪ w ͙Β͍͔͠ΠϯσοΫε͞Εͳ͍ w λά͕ؒҧ͍ͬͯΔͱ͔͸ͳͦ͞͏ w ΍ͬͺΓ443͠ͳ͍ͱ͍͚ͳ͍ͷ͔ɾɾɾʁ

Slide 13

Slide 13 text

ͦ΋ͦ΋443ͱ͸ wαʔόʔαΠυϨϯμϦϯά w αʔόʔଆͰ༧Ί+4Λ࣮ߦͯ͠%0.Λߏஙͯ͠ ͔ΒϨεϙϯεΛฦ͢

Slide 14

Slide 14 text

ΫϥΠΞϯταΠυϨϯμϦϯά αʔόʔ ϒϥ΢β EJWEJW EJW UBCMFDMBTTGPP  UBCMF EJW 'PP5BCMF IUNM +4 ΄΅ۭͷIUNMΛฦ͢ ΫϥΠΞϯτଆͰ3FBDU SFOEFSͯ͠ IUNMΛߏங͢Δ

Slide 15

Slide 15 text

αʔόʔαΠυϨϯμϦϯά αʔόʔ ϒϥ΢β EJW UBCMFDMBTTGPP  UBCMF EJW αʔόʔଆͰ 3FBDUSFOEFSͯ͠ IUNMΛ׬੒͔ͤͯ͞Β Ϩεϙϯε

Slide 16

Slide 16 text

3BJMTͰ443͢Δ৔߹ wSFBDUSBJMT w 3BJMT্Ͱ&YFD+4ͰϨϯμϦϯά wIZQFSOPWB w 3BJMTͱ͸ผͷIZQFSOPWBαʔόʔʢ/PEFKT&YQSFTTʣͰϨϯμϦϯ άͯ͠3BJMT্ͰϚʔδ wSFBDU@PO@SBJMT w σϑΥϧτ͸&YFD+4͕ͩ1SP൛͸/PEF7.͕࢖͑ΔΒ͍͠

Slide 17

Slide 17 text

&YFD+4 w3VCZ͔Β+4Λ࣮ߦ͢Δ wϥϯλΠϜ͍Ζ͍Ζ w MJCWܥ UIFSVCZSBDFS NJOJ@SBDFS  w /PEFKT w FUD wศར͕͍ͩΖ͍Ζ੍ݶ͸͋Δ w +4&WFOUMPPQʹ׬શʹ͸ରԠ͓ͯ͠ΒͣɺTFU5JNFPVUͱ͔࢖͑ͳ͍

Slide 18

Slide 18 text

SFBDUSBJMT w3BJMT XFCQBDLFS Ͱ3FBDU࢖͏ͳΒͨͿΜ͔͜͜Β w SBJMTXFCQBDLFSJOTUBMMͰೖΔ w Φ΢νʔϊͰ΋࠷ॳ͜ΕΛ࢖͍ͬͯͨ w443͕؆୯ w ΦϓγϣϯΛQSFSFOEFSUSVFʹ͢Δ͚ͩʂ w ૣ଎༗ޮʹͯ͠Έͨ

Slide 19

Slide 19 text

େྔͷΤϥʔͰશવಈ͔ͳ͍ w&YFD+4ଆͰϒϥ΢βݻ༗ͷ΋ͷʹ৮Δͱଈࢮ w XJOEPX MPDBM4UPSBHF FUD w UZQFPGXJOEPXͳͲ੍ͯ͠ޚͯ͠΍Δඞཁ͕͋Δ w6OJWFSTBM+BWB4DSJQUԽ w ϒϥ΢βͰ͔͠ಈ͔ͳ͍࣮૷Λ͠ͳ͍Α͏मਖ਼ w Ͱ΋ϝσΟΞΫΤϦͱ͔MPDBM4UPSBHF࢖͍͍ͨɾɾɾ

Slide 20

Slide 20 text

؀ڥґଘͷίʔυΛந৅Խ class DeviceDetector { constructor(userAgent) { // CSRではメディアクエリ、SSRではUAを使う if ((typeof window) === 'undefined') { this.detector = new UADetector(userAgent) } else { this.detector = new MediaDetector() } } } // メインコードでは環境を意識せずに使う deviceDetector = new DeviceDetector(this.props.user_agent) if (deviceDetector.isSmartPhone()) { ... }

Slide 21

Slide 21 text

)5.-ฦͬͯ͘ΔΑ͏ʹͳͬͨ wҰ෦ͷίϯςϯπ͕දࣔ͞Εͳ͍ w "1*ͰσʔλΛऔಘͯ͘͠Δ෦෼ w Ͳ͏΍ΒSFEVYTBHB͕࣮ߦ͞Ε͍ͯͳ͍

Slide 22

Slide 22 text

SFEVYTBHB w3FEVYͰඇಉظॲཧΛѻ͏NJEEMFXBSF class EstateComponent extends React.Component { handleClick() { // Reducerのときと同じようにdispatch dispatch({ type: 'REQUEST_FIND_ESTATE', params: { this.props.estateId } }) } } function* estateSaga() { yield takeEvery('REQUEST_FIND_ESTATE', fetchEstate) } function* fetchEstate(action) { try { const estate = yield call(API.fetchEstate, action.params.estateId) // 結果をreducerにdispatch yield put({ type: 'SUCCESS_FIND_ESTATE', estate }) } catch (e) { yield put({ type: 'FAILURE_FIND_ESTATE', message: e.message }) } }

Slide 23

Slide 23 text

$43ͰͷTBHB ϒϥ΢β 3FBDU 4BHB 4BHBTUBSU SFOEFS EJTQBUDI "1*GFUDI 5BLFBDUJPO EJTQBUDI 3FEVDFS 6QEBUFDPNQPOFOU ֓೦ͱͯ͠͸ ผʑͷεϨουͰ ಈ͘Πϝʔδ SFOEFS࣌ ൃߦ͞ΕͨBDUJPO܈Λ TBHB͕रͬͯ EJTQBUDIͯ͠໭͢

Slide 24

Slide 24 text

ͦͷ··443͢Δͱ &YFD+4 3FBDU 4BHB 4BHBTUBSU SFOEFS EJTQBUDI 4BHB͕ಈ͘લʹSFOEFS ؔ਺͕ऴྃ͢Δ 3BJMT 4BHB͕ಈ͔ͳ͍ঢ়ଶͰ ͷIUNMΛฦͯ͠͠·͏

Slide 25

Slide 25 text

ճSFOEFS͢Δ 3FBDU 4BHB SFOEFS EJTQBUDI "1*GFUDI 5BLFBDUJPO EJTQBUDI 3FEVDFS &/%BDUJPO͸ ࣮ߦதͷTBHBλεΫ͕ ऴྃͨ͠ΒTBHB΋ऴྃ &/%EJTQBUDI 4BHBTUPQ 3FEVYTUPSF 3FBDU SFOEFS 3BJMT ॳճSFOEFSͨ͠Β &/%EJTQBUDI ̍ճ໨ͷ TUPSFΛ࢖ͬͯ ࠶౓SFOEFS

Slide 26

Slide 26 text

TBHBͷ443ํ๏ʢެࣜʣ store.runSaga(rootSaga).toPromise().then(() => { // sagaが終了したらrenderして返すコールバック res.status(200).send( layout( renderToString(rootComp), JSON.stringify(store.getState()) ) ) }).catch((e) => { res.status(500).send(e.message) }) renderToString(rootComp) // 1回目のrender store.close() // END actionをdispatch

Slide 27

Slide 27 text

ճSFOEFS๏ͷ໰୊ wϨεϙϯεฦ͢ਓ͕1SPNJTFΛѻ͑Δ ඞཁ͕͋Δ w ެࣜαϯϓϧ͸/PEFKT w &YFD+4ˠ3BJMTͷ৔߹͸ίʔϧόοΫΛ଴ͯͳ͍

Slide 28

Slide 28 text

)ZQFSOPWB w"JSCOC੡443πʔϧ 3BJMT )ZQFSOPWB /PEFKT SFOEFS SFOEFS3FBDU .FSHF )ZQFSOPWB͔Βͷ )5.-Λ3BJMTςϯϓϨʔ τจࣈྻʹૠೖ 1SPNJTFͰฦͤ͹ ίʔϧόοΫͷ݁ՌΛ ฦͯ͘͠ΕΔ

Slide 29

Slide 29 text

)ZQFSOPWBͰTBHB΋ಈ͘Α͏ʹͳ͕ͬͨɾɾɾ w·ͩ෦෼తʹදࣔ͞Εͳ͍ w TBHBλεΫͷ݁ՌͰผͷTBHBλεΫ͕ಈ͘Օॴ w&/%BDUJPO͸ͦͷ࣌఺ͰͷλεΫͷ׬ྃΛ଴ͭ w &/%EJTQBUDIޙʹ৽͘͠ൃߦ͞ΕͨBDUJPO͸଴ͨͳ͍ wͱΓ͋͑ͣ֘౰λεΫ͸Ұͭʹ·ͱΊͯճආ w ૄ݁߹ੑΣɾɾɾ

Slide 30

Slide 30 text

ίϯςϯπ͸443Ͱ͖ΔΑ͏ʹͳͬͨʂ wUJUMFλά͕ग़ͳ͍ɾɾɾ

Slide 31

Slide 31 text

3FBDUIFBE +49Ͱهड़͓͚ͯ͠͹ ·ͱΊͯIFBEΛ࡞ͬͯ ͘ΕΔ const App = () => (
Title of page // ...
)

Slide 32

Slide 32 text

3FBDUIFBEͷ443 BU/PEFKT const headTags = []; const app = renderToString( ); res.send(` ${renderToString(headTags)}
${app}
`); SFOEFS͢Δͱ IFBE5BHTʹ IFBE༻ίϯϙʔω ϯτ͕ूΊΒΕΔ IFBE5BHT͚ͩΛ ࠶౓SFOEFSͯ͠ ϨΠΞ΢τʹຒΊ ࠐΉ

Slide 33

Slide 33 text

)ZQFSOPWB͸EJWλάͷத਎͚ͩΛฦ͢ !!! %html %head %meta{:content => "text/html; charset=UTF-8"... ... %body ... = render_react_component('app', react_props) ϨΠΞ΢τ͸ 3BJMTଆʹ͋Δ IZQFSOPWBSVCZ͕ IZQFSOPWBTFSWFS ͔Βฦ͖ͬͯͨIUNM ยͰஔ׵

...

SFBDUIFBEͰ ผ్SFOEFSͨ͠΋ͷΛ Ͳ͏΍ͬͯ3BJMTଆʹ౉͢ʁ

Slide 34

Slide 34 text

Ұॹʹฦͯ͠ஔ׵ʢྗٕʣ !!! %html %head %meta{:content => "text/html; charset=UTF-8"... ... %hypernova-head-tags/ %body ... = render_react_component('app', react_props) SFBDUIFBEʹSFOEFSͤ͞ ͨ΋ͷΛಠࣗλάͰҰॹ ʹฦ͢ IZQFSOPWBSVCZ͕ ஔ׵ͨ͠ޙʹ ϚʔΧʔλάΛஔ׵ ...

...

Slide 35

Slide 35 text

͍͍ͩͨ443Ͱ͖ͨʂࣾ಺Ͱ৮ͬͯ΋Β͏ wදࣔ͸Ͱ͖ͯΔ͚Ͳಈ͖͕͓͔͍͠ w ݕࡧͨ͜͠ͱͳ͍৔ॴͷ݁Ռ͕ग़ͯ͘Δ

Slide 36

Slide 36 text

άϩʔόϧม਺ʹͳͬͯͨ wΫϥε֎ͷม਺ͳͲ w $43Ͱ͔͠ಈ͍͍ͯͳ͔ͬͨͷͰ໰୊ͳ͔ͬͨ wҰͭҰͭ௚ͨ͠

Slide 37

Slide 37 text

443ϦϦʔεʂ

Slide 38

Slide 38 text

ΠϯσοΫε ͞Εͳ͔ͬͨɾɾɾ

Slide 39

Slide 39 text

΋͔ͯ͠͠දࣔ଎౓ɾɾɾʁ wUFTUNZTJUF w (ճઢͰඵ͔͔Δͱ͍͏ධՁ wੵΈ*TTVFʹ͍ͯͨ͠ w ࣮ճઢͰ࢖͍ͬͯΔݶΓ͸ͦ͜·Ͱ஗͘ײ͍ͯ͡ͳ͔ͬͨ w શମ੾Γସ͑લʹ͸ͪΌΜͱ΍Ζ͏ͱࢥ͍ͬͯͨ

Slide 40

Slide 40 text

ϘτϧωοΫ w+BWB4DSJQUϑΝΠϧͷμ΢ϯϩʔυ࣌ؒ w ϑΝΠϧͰ.Φʔόʔ w XFCQBDLͰ͢΂͕ͯόϯυϧ͞ΕͨϑΝΠϧʹͳΔͨΊ w 443͍ͯ͠Δͷʹ+4ϑΝΠϧ͕ϘτϧωοΫʁ w 3FBDUIZESBUF׬ྃ·Ͱ͸%0.$POUFOU-PBEFEʹͳΒͳ͍ ʢৄࡉ͸ޙड़ʣ

Slide 41

Slide 41 text

$PEF4QMJUUJOH w7FOEPS$PEF4QMJUUJOH w%ZOBNJD*NQPSUT ·ͣ͸͔ͬͪ͜Β

Slide 42

Slide 42 text

7FOEPS$PEF4QMJUUJOH wࢦఆͨ͠ϞδϡʔϧΛผϑΝΠϧʹ੾Γग़͢ w XFCQBDLDPOpHʹϧʔϧϕʔεͰઃఆ͢Δ wQSPTDPOT w ࣮૷Λมߋ͢Δඞཁ͕ͳ͍ w ϧʔϧ͕૿͑ΔͱΧΦε w ෼ׂͰ͖Δཻ౓͕ߥ͍

Slide 43

Slide 43 text

$PNNPOT$IVOL1MVHJO w$PEFTQMJUUJOH༻ͷXFCQBDLQMVHJO w XFCQBDLWͰ͸4QMJU$IVOLT1MVHJOʹͳ͍ͬͯΔ w XFCQBDLFSͰ͸QSFͰXFCQBDLWରԠ w ౰࣌XFCQBDLFS͸WʹରԠ͍ͯ͠ͳ͔ͬͨ w ෳ਺ͷϧʔϧΛఆٛ͢Δ৔߹෼͔ΓͮΒ͍

Slide 44

Slide 44 text

$PNNPOT$IVOL1MVHJO clientPlugins.push( new webpack.optimize.CommonsChunkPlugin({ name: 'vendor', minChunks: (m) => /node_modules/.test(m.context) }), ); clientPlugins.push( new webpack.optimize.CommonsChunkPlugin({ name: 'd3_chunk', minChunks: (m) => /node_modules\/(?:d3|redux)/.test(m.context) }), ); clientPlugins.push( new webpack.optimize.CommonsChunkPlugin({ name: 'redux_chunk', minChunks: (m) => /node_modules\/(?:redux)/.test(m.context) }), ); ໊લϕʔεͰϚον ޷͖ͳཻ౓Ͱ DIVOLʹͰ͖Δɺ͕ Ϛονͷ฼ूஂ͕ લճͷϚονର৅ͳͷͰ ্ྲྀ͸ԼྲྀΛશؚͯΉ

Slide 45

Slide 45 text

#VOEMF"OBMZ[FS1MVHJO $PNNPOT$IVOL1MVHJO ϧʔϧΛௐ੔ͯ͠ ࠷େͰ΋,ʹऩ·Δ Α͏ʹௐ੔

Slide 46

Slide 46 text

ͪΐͬͱ଎͘ͳͬͨ TT

Slide 47

Slide 47 text

ΠϯσοΫε ͞Ε࢝Ίͨʂʂʂ

Slide 48

Slide 48 text

ͲΜͲΜ෼ׂ

Slide 49

Slide 49 text

XFCQBDLDPOpHͷ෼཭ w$43༻ͱ443༻ͰDPOpHΛ෼཭ w $PEFTQMJUUJOH͕ඞཁͳͷ͸$43͚ͩ w 443࣌͸DIVOL͕Θ͔Ε͍ͯΔͱNBOJGFTU͔ΒEJHFTUͷղܾ΋͢Δඞཁ ͕͋Δ w ͦ΋ͦ΋෼͚ΔϝϦοτ͕͋·Γແ͍ w 6OJWFSTBM+4͕΍Γ΍͘͢ͳΔ w ͨͩBTTFUDPNQJMFͷ࣌ؒ͸৳ͼΔɾɾɾ

Slide 50

Slide 50 text

7FOEPS$PEF4QMJUUJOHͷน wґଘؔ܎͸อূ͞Εͳ͍ w BTZODMPBEͰ͖ͳ͍ w ແཧ΍Γ෼ׂ͢ΔͱյΕΔ wDIVOL͸ϥΠϒϥϦͷαΠζΑΓখ͘͞Ͱ͖ͳ͍ w ར༻͍ͯ͠ͳ͍ͱ͜Ζ΋όϯυϧ͞Εͯ͠·͏ wDIVOL෼ׂ͕৬ਓܳԽ

Slide 51

Slide 51 text

$PEF4QMJUUJOH w7FOEPS$PEF4QMJUUJOH w%ZOBNJD*NQPSUT ΍ͬͺΓ͔ͬͪ͜

Slide 52

Slide 52 text

%ZOBNJD*NQPSUT import(/* webpackChunkName: "raven" */ 'raven-js').then((Raven) => { Raven.config( 'endpoint', { environment: this.props.railsEnv, release: this.props.revision } ).install() })

Slide 53

Slide 53 text

%ZOBNJD*NQPSUT wQSPTDPOT w ґଘੑΛߟྀͰ͖Δ w ͖Ίࡉ΍͔ʹ෼ׂ͠΍͍͢ w EZOBNJDJNQPSUTΛߟྀ࣮ͨ͠૷͕ඞཁ w ର৅ΛҰՕॴͰ΋௨ৗJNQPSU͢Δͱ෼ׂ͞Εͳ͍ w ίʔϧόοΫ੍ޚͭͭ͠ίϯϙʔωϯτߏங͢ΔͭΒΈ

Slide 54

Slide 54 text

SFBDUMPBEBCMF w3FBDUίϯϙʔωϯτΛEZOBNJDJNQPSUT ʹͯ͘͠ΕΔ)0$ϥΠϒϥϦ import Loadable from 'react-loadable' const Lightbox = Loadable({ loader: () => import(/* webpackChunkName: "react-images" */ 'react-images'), loading() { return
Loading...
} }) ˞MPBEBCMFDPNQPOFOUTͱ͔΋Αͦ͞͏

Slide 55

Slide 55 text

SFBDUMPBEBCMF wQSPTDPOT w ίϯϙʔωϯτΛ؆୯ʹEZOBNJDJNQPSUTʹͰ͖Δ w ͢Ͱʹ)0$ʹͳ͍ͬͯΔ΋ͷͱ૬ੑ͕ѱ͔ͬͨΓ͢Δ w 6*ܥʹద༻͢Δͱ͔ͤͬ͘443Ͱදࣔ͞ΕͯΔͷʹޙ͔ ΒҰॠ-PBEJOHʹͳͬͨΓ w ґଘؔ܎͕ෳࡶͳίϯϙʔωϯτͰΧΦεʹͳΓ΍͍͢

Slide 56

Slide 56 text

݁ہ๚ΕΔίʔϧόοΫ஍ࠈ wBXBJUͰ੍ޚ͍ͨ͠ w ݸผʹBTZODGVODUJPOʹͰ͖Δͱ͜Ζ͸ྑ͍ w IZQFSOPWB͔ΒHFU$PNQPOFOU͞ΕͯCVJME͍ͯ͠ ͘Ͳ͔͜ͰٵऩͰ͖ͨΒɾɾɾΜʁ

Slide 57

Slide 57 text

IZQFSOPWBͳΒ͍͚Δ wճSFOEFSͷͨΊʹͦ΋ͦ΋1SPNJTFͰ ฦ͍ͯͨ͠ w CVJME$PNQPOFOUࣗମΛBTZODʹͨ͠ w ඞཁͳՕॴͰͷBXBJU͕΍Γ΍͘͢ͳͬͨ w ػೳ͝ͱʹάϧʔϐϯάͯ͠DIVOL෼ׂ

Slide 58

Slide 58 text

TDSJQUͷBTZODϩʔυ wTDSJQUࣗମΛBTZODʹͯ͠μ΢ϯϩʔυɾ ࣮ߦΛඇಉظʹ͢Δ w $PNNPOT$IVOL1MVHJOͰ͸ґଘੑΛ୲อͰ͖ͳ ͘ͳΔͷͰ࢖͑ͳ͔ͬͨ w )5.-ύʔεΛ଴ͨͣʹμ΢ϯϩʔυͰ͖Δ

Slide 59

Slide 59 text

·͊·͊଎͘ͳͬͨ TT ʢΑ͏΍͘ʮී௨ʯ൑ఆʣ

Slide 60

Slide 60 text

ͲͷλΠϛϯάͰϩʔυ׬ྃͱͳΔ͔ʁ w͜Ε·Ͱ%0.$POUFOU-PBEFE΍MPBEΠϕ ϯτΛ໨҆ʹ͍ͯͨ͠ wMPBEΠϕϯτͷλΠϛϯάΑΓUFTUNZTJUF ͷධՁ͕஗͍ʁ w MPBEΠϕϯτ͕Φ΢νΑΓ஗͍αΠτͰ΋UFTUNZTJUF ͷධՁ͕଎͍ͱ͜Ζ΋͋ͬͨ

Slide 61

Slide 61 text

ը૾ͷ஗ԆϩʔυΛʢҰ෦ʣ΍ΊΔ wը૾͸+4Ͱ஗ԆಡΈࠐΈ͍ͯͨ͠ w 443ͷஈ֊Ͱ͸μϛʔͷը૾͔͠ೖΒͳ͍ w 3FBDUIZESBUF͕׬ྃ͢Δ·ͰϑΝʔετϏϡʔͷը૾μ ΢ϯϩʔυ͕։࢝͞Εͳ͍ wϑΝʔετϏϡʔ͚ͩ஗ԆϩʔυΛ΍Ίͨ w 443͍ͯ͠ΔͷͰ+4ͷධՁΛ଴ͨͣʹը૾͕දࣔ͞ΕΔ

Slide 62

Slide 62 text

ΘΓͱ଎͘ͳͬͨ TT ʢʮྑ޷ʯ൑ఆʣ

Slide 63

Slide 63 text

଎͘ͳΔʹͭΕͯ ΠϯσοΫε΋૿͑ͨ

Slide 64

Slide 64 text

݁࿦ w41"Ͱ͋ͬͯ΋4&0ͷجຊ͸ಉ͡ w ద੾ͳαΠτߏ଄΍λάઃఆΛߦ͏ w දࣔ଎౓Λ্͛Δ w ஗͍ͱΠϯσοΫε͞Εͳ͍Մೳੑ͕͋Δ w ଎͚Ε͹443͸ඞਢͰ͸ͳ͍͔΋

Slide 65

Slide 65 text

41"ͷύϑΥʔϚϯε͸ཁ஫ҙ wωοΫʹͳΓ΍͍͢ϙΠϯτ w +4ͷϑΝΠϧαΠζ w γʔέϯγϟϧͳ"1*ίʔϧ w$43Ͱಈ͔͍ͯ͠Δͱؾ͖ͮͮΒ͍৔߹͕͋Δ w ࠩ෼͚ͩมߋ͞Ε͍ͯͨ͘Ί w443͸଎౓ͷͨΊͷҰͭͷखஈ

Slide 66

Slide 66 text

443ͷϝϯςφϯε͸݁ߏେม w։ൃத͸$43Ͱಈ͔͍ͯ͠Δ w ͏͔ͬΓXJOEPX৮ͬͨΓͯ͠΋ؾ͔ͮͳ͍ w443 /PEFKTଆ ͰΤϥʔ͕ग़ͨΒࣗಈͰ$43ʹͳΔΑ͏ʹͯ͠ ͍Δ w ϢʔβʔӨڹແ͍෼ؾ͖ͮͮΒ͍ wTUBHJOHσϓϩΠ͞ΕͨΒ&&ςετͰ443͞Ε͍ͯΔ͔νΣοΫ w ͳΔ΂͘ૣΊʹݕ஌

Slide 67

Slide 67 text

8FSFIJSJOH ࣍ͷΦ΢νʔϊΛ͍ͬ͠ΐʹ࡞Γ·ͤΜ͔ SFDSVJU!PVDDJOPKQ IUUQTDPSQPSBUFPVDDJOPKQSFDSVJU ։ൃऀϒϩάIUUQTEFWFMPQFSTPVDDJOPDPN