Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
PHPerのためのVue.js入門とVue.js 2.0の未来
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
hypermkt
November 03, 2016
Programming
13k
13
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
PHPerのためのVue.js入門とVue.js 2.0の未来
hypermkt
November 03, 2016
More Decks by hypermkt
See All by hypermkt
プロポーザルを書くときに 私が考えていること/what-i-think-about-when-writing-a-proposal
hypermkt
0
620
履歴 on Rails: Bitemporal Data Modelで実現する履歴管理/history-on-rails-with-bitemporal-data-model
hypermkt
1
4.5k
Sidekiqで実現する 長時間非同期処理の中断と再開 / Pausing and Resuming Long-Running Asynchronous Jobs with Sidekiq
hypermkt
8
6.7k
脆弱性から学ぶ Webセキュリティ Part2/study-web-security-from-vulnerability2
hypermkt
5
3.5k
脆弱性から学ぶ Webセキュリティ/study-web-security-from-vulnerability1
hypermkt
5
2.6k
モバイルアプリ向けAPI 開発を通じて学んだこと / learned-from-developing-mobile-app-api
hypermkt
3
4.8k
Passportのパスワードグラントで独自の認証を実装する方法 / how-to-implement-original-authentication-for-passport-password-grant
hypermkt
1
860
Webpackで作る Vueコンポーネント開発環境 / Creating the Vue component development with Webpack.
hypermkt
3
4.4k
あの問題解きました! / solved the code
hypermkt
0
360
Other Decks in Programming
See All in Programming
Old Dog, New Tricks: The Java 25 Reinvention - JNation
bazlur_rahman
0
150
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
480
3Dシーンの圧縮
fadis
1
680
Observability in Practice:Grafana 與 Edge Device SRE 的那些事
blueswen
0
150
「エンジニアインターン、どうやって取った?」準備のリアルを語るLT会 Progate BAR
akiomatic
0
120
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
520
AI時代のUIはどこへ行く?その2!
yusukebe
19
6.9k
TSKaigi Night Talks 2026_TypeScriptでサプライチェーンの整合性を型に閉じ込める
geekplus_tech
0
330
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
520
Modding RubyKaigi for Myself
yui_knk
0
910
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
550
AI駆動開発で崩れていくコードベースを立て直す
kyoko_nr_nr
1
450
Featured
See All Featured
Navigating Weather and Climate Data
rabernat
0
210
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.7k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
46
2.9k
AI Search: Implications for SEO and How to Move Forward - #ShenzhenSEOConference
aleyda
1
1.3k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.9k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.3k
BBQ
matthewcrist
89
10k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
2
210
AI: The stuff that nobody shows you
jnunemaker
PRO
8
700
Effective software design: The role of men in debugging patriarchy in IT @ Voxxed Days AMS
baasie
0
400
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Transcript
όʔνʔ(.01&1"#0JOD 1)1ΧϯϑΝϨϯε 1)1FSͷͨΊͷ7VFKTೖͱ 7VFKTͷະདྷ
1)1FS (.0ϖύϘάʔϖνʔϜ ιϑτΣΞΤϯδχΞ Ξχϝ෦෦ όʔνʔ!IZQFSNLU IUUQCMPHIZQFSNLUKQ
ϗʔϜϖʔδ࡞αʔϏεάʔϖ IUUQTHPPQFKQ
ΞχϝͷϨϏϡʔαΠτʮ͋ʹ͜Εʯ IUUQTXXXBOJLPSFKQ
ࠓ͢͜ͱ wഎܠ w7VFKTೖ w֤छจ๏ͷհ w7VFKTίϛϡχςΟ w7VFKTͷະདྷ w·ͱΊ
എܠ
1)1ΧϯϑΝϨϯεͰͳͥ7VFKT
ཧ༝͕̎ͭ͋Γ·͢
ᶃ 1)1FSͱͯ͠7VFKTΛԠԉ͍ͨ͠ʂ ᶄૉΒ͍͠ϥΠϒϥϦͳͷͰօ͞Μʹ ͬͯ΄͍͠ʂ
-BSBWFM͔Β7VFKT͕ެࣜϑϩϯτΤϯυϥΠϒϥϦʹ ཧ༝̍
ϑϩϯτΤϯυॳ৺ऀ ࢲ ͰษڧΛ࢝Ίͯ ͙͢ʹίʔυΛॻ͖࢝ΊΔ͜ͱ͕ग़དྷͨ ཧ༝̎
ࢲͷ+BWB4DSJQUϨϕϧ w݄࣌ wK2VFSZͰ͔͠+BWB4DSJQUΛॻ͍ͨ͜ͱ͕ͳ͘ɺ࠷ۙͷ·͙Δ͠ ͍มԽʹযΓΛײ͡Δ ؾͮ͘ͷ͍ w݄ɿ+BWB4DSJQUͷجૅΛษڧͨ͢͠ΊຊΛങ͍ړΔ w݄ɿ"OHVMBS+4YͷษڧΛຊΛݟͳ͕Β࢝ΊΔ͕࠳ંPS[
݄ʹ7VFKTͱग़ձ͏
7VFKTͷษڧΛ࢝ΊΔ wಥવόϦσʔγϣϯϥΠϒϥϦWVFWBMJEBUPSυΩϡϝϯτͷ༁Λ ͢Δ w݄7VFKT5PLZP.FFUVQlzͰʮ༁͔Β࢝ΊΔ 7VFKTೖʯΛൃද IUUQXXXTMJEFTIBSFOFUIZQFSNLUWVFKT
݄ձࣾͷ։ൃ߹॓ͰࣾใγεςϜΛ7VFKTͰ։ൃ wใͷӾཡɾߘɺ͍͍ͶɺԻಡΈ্͛ػೳ w։ൃ࣌7VFKTܥ WVFSPVUFS WVFSFTPVSDF WVFJGZ wϦϦʔεޙʹόʔδϣϯΞοϓ
%FNP
7VFKTͱ
7VFKTͱ wϢʔβʔΠϯλʔϑΣΠεΛߏங͢ΔͨΊͷϓϩάϨογϒϑϨʔϜ ϫʔΫ wنʹԠͯ͡ՃͰ͖Δؔ࿈ϥΠϒϥϦ wγϯϓϧͳ"1* wϑϧελοΫͰͳ͍
ਓؾͷཧ༝ wγϯϓϧͳ"1*͔ͭ؆୯ͳςϯϓϨʔτͰֶशίετ͕͍ wίϯϙʔωϯτࢦͷ6* wߴ͔ͭܰྔ LCNJO H[JQ࣌ wϨϯμϦϯά͕͍
7VFKTೖ ରԠ൛
͜Ε͚֮ͩ͑Ε͍͍ͩͨ0,ʂ wಋೖํ๏ wσʔλόΠϯσΟϯά wํόΠϯσΟϯά wϦετϨϯμϦϯά wϝιουͱΠϕϯτϨϯμϦϯά w͖݅ϨϯμϦϯά wΫϥεͱελΠϧͷόΠϯσΟϯά wίϯϙʔωϯτ wͷҙ
ಋೖํ๏
Ұ൪؆୯ͳಋೖํ๏ // index.html <!-- Vue.js͔Βར༻͢ΔHTML͜͜ʹॻ͘ --> <!-- Vue.jsຊདྷΛCDN͔ΒಡΈࠐΉ --> <script
type="text/javascript" src="https://cdnjs.cloudflare.com/ ajax/libs/vue/2.0.3/vue.js"></script> <!-- Vue.jsΛར༻ͨ͠JavaScriptίʔυ͜͜ʹॻ͘ -->
σʔλόΠϯσΟϯάͱ7VFͷجૅ
มల։Ϛελογϡه๏Ͱ \\NFTTBHF^^
σʔλόΠϯσΟϯά // main.js new Vue({ // ରΤϨϝϯτΛࢦఆ͠·͢ el: '#app', //
Vue ΠϯελϯεͷͨΊͷσʔλΦϒδΣΫτ data: { message: 'Hello PHPΧϯϑΝϨϯε2016ʂ' } }); // index.html <div id="app"> {{ message }} </div> ᶃ7VFΠϯελϯεΛ࡞ ᶄରΤϨϝϯτΛࢦఆ ᶅσʔλΦϒδΣΫτΛઃఆ ᶆςΩετల։͞ΕΔ
ϒϥβදࣔ݁Ռ
ํόΠϯσΟϯά
WNPEFMσΟϨΫςΟϒ // index.html <div id="app"> {{ message }} <input type=”text”
v-model=”message”> </div> 'PSNͷJOQVUUFYUBSFBΛEBUBΦϒδΣΫτͱํʹσʔλόΠϯ σΟϯά͕ग़དྷΔ
ํόΠϯσΟϯά // main.js new Vue({ // ରΤϨϝϯτΛࢦఆ͠·͢ el: '#app', //
Vue ΠϯελϯεͷͨΊͷσʔλΦϒδΣΫτ data: { message: 'Hello PHPΧϯϑΝϨϯε2016ʂ' } }); // index.html <div id="app"> {{ message }} <input type=”text” v-model=”message”> </div> ಉظ͞ΕΔ ༰ө͞ΕΔ
࣮ߦ͢Δͱ ςΩετϘοΫεͷจࣈΛมߋ͢Δͱ ϦΞϧλΠϜͰ্ʹө͞ΕΔ
ϦετϨϯμϦϯά ͜ΕΛ֮͑Δͱ̋̋Ұཡ͕ԿͰ࣮Մೳʹ
ϦετϨϯμϦϯά // main.js new Vue({ el: '#app', data: { items:
[ { title: 'PHP' }, { title: 'Conference2016' }, { title: '201611݄3ʢʣ' }, { title: 'େా۠࢈ۀϓϥβ PiO' } ] } }); // index.html <div id="app"> <ul> <li v-for="item in items"> {{ item.title }} </li> </ul> </div> ᶃྻΛࢦఆ͢Δ ᶄϦετల։͞ΕΔ
ϒϥβදࣔ݁Ռ
WGPSσΟϨΫςΟϒ // index.html <div id="app"> <ul> <li v-for="item in items">
{{ item.title }} </li> </ul> </div> JUFNJOJUFNTܗࣜͰྻͷத Λల։ͭͭ͠܁Γฦ͠ॲཧΛ࣮ߦ ͢Δ
7VFKTͰར༻Ͱ͖ΔσΟϨΫςΟϒҰཡ WUFYU WIUNM WJG WTIPX WFMTF WGPS WFM WPO WCJOE
WNPEFM WQSF WDMPBL WPODF WSFG EFQSFDBUFE EFQSFDBUFE OFX
Α͘ར༻͢ΔσΟϨΫςΟϒҰཡ WUFYU WIUNM WJG WTIPX WFMTF WGPS WFM WPO WCJOE
WNPEFM WQSF WDMPBL WPODF WSFG EFQSFDBUFE EFQSFDBUFE OFX
ϝιουͱΠϕϯτϨϯμϦϯά ͔͜͜Βͬͱಈ͖͕ग़ͯ͘Δʂ
WPOσΟϨΫςΟϒ )5.-ཁૉʹΠϕϯτΛઃఆ͢Δ ͜ͱ͕ग़དྷ·͢ <div id="app"> {{ message }}<br /> <button
v-on:click=“sayHi()"> Hi! </button> </div>
ϝιουͱΠϕϯτϨϯμϦϯά // main.js new Vue({ el: '#app', data: { message:
'∥౬෩࿊∥' }, created: function() { setTimeout(function() { alert('ԡͤΑʔʂ'); }, 5000); }, methods: { push: function() { this.message = 'ૌ͑ͯΔʂ'; } } }); // index.html <div id="app"> {{ message }}<br /> <button v-on:click=“push()"> ઈରʹԡ͢ͳΑʂ </button> </div> ϥΠϑαΠΫϧϑοΫ Πϯελϯε͕࡞͞ΕͨޙʹݺΕ·͢ɻ
ϝιουͱΠϕϯτϨϯμϦϯά // main.js new Vue({ el: '#app', data: { message:
'∥౬෩࿊∥' }, created: function() { setTimeout(function() { alert('ԡͤΑʔʂ'); }, 5000); }, methods: { push: function() { this.message = 'ૌ͑ͯΔʂ'; } } }); // index.html <div id="app"> {{ message }}<br /> <button v-on:click=“push()"> ઈରʹԡ͢ͳΑʂ </button> </div> ϝιουఆٛՕॴ 7VFKTͰϝιουఆٛ͜ͷNFUPET ͱܾ·͍ͬͯ·͢ɻ ͜͜Ͱએݴͨ͠ϝιουΠϯελϯεɺ ςϯϓϨʔτ͔Βݺͼग़ͤ·͢ɻ
࣮ߦ͢Δͱ ඵޙʹදࣔ͞ΕΔ ϘλϯΛԡ͢ͱϝοηʔδ͕มΘΔ
͖݅ϨϯμϦϯά
WJGσΟϨΫςΟϒ ݅ʹԠͯ͡ΤϨϝϯτͷදࣔɾ ඇදࣔΛΓସ͑ΒΕΔ <p v-if=“isActive"> ༗ޮͳΞΧϯτͰ͢ </p> <p v-if="age >=
20”> ਓͰ͢ </p>
WFMTFσΟϨΫςΟϒ͕ศརʂʂ WJGͷޙʹஔ͢Δ͜ͱͰɺ લͷWJGͷFMTFCMPDLͱͯ͠දࣔ ͞Ε·͢ <p v-if="age >= 20”> ਓͰ͢ </p>
<p v-else> ະͰ͢ </p>
͖݅ϨϯμϦϯά // main.js new Vue({ el: '#app', data: { isHandRaised:
false }, methods: { raiseHand: function() { this.isHandRaised = true; } } }); // index.html <div id="app"> <p v-if=“isHandRaised”>Ͳ͏ͧͲ͏ͧ</p> <p v-else> ͓લΒͳ͍ͷ?͡Ό͋Զ͕ΔΑ!<br /> ͍͜͜Զ͕ΔΑ! <br /> <button v-on:click=“raiseHand">ɾɾɾ͡Ό͋Զ ͕ΔΑɻ</button> </p> </div> ϝιουͱมఆٛ
͖݅ϨϯμϦϯά // main.js new Vue({ el: '#app', data: { isHandRaised:
false }, methods: { raiseHand: function() { this.isHandRaised = true; } } }); // index.html <div id="app"> <p v-if=“isHandRaised”>Ͳ͏ͧͲ͏ͧ</p> <p v-else> ͓લΒͳ͍ͷ?͡Ό͋Զ͕ΔΑ!<br /> ͍͜͜Զ͕ΔΑ! <br /> <button v-on:click=“raiseHand">ɾɾɾ͡Ό͋Զ ͕ΔΑɻ</button> </p> </div> Πϕϯτઃఆ
͖݅ϨϯμϦϯά // main.js new Vue({ el: '#app', data: { isHandRaised:
false }, methods: { raiseHand: function() { this.isHandRaised = true; } } }); // index.html <div id="app"> <p v-if=“isHandRaised”>Ͳ͏ͧͲ͏ͧ</p> <p v-else> ͓લΒͳ͍ͷ?͡Ό͋Զ͕ΔΑ!<br /> ͍͜͜Զ͕ΔΑ! <br /> <button v-on:click=“raiseHand">ɾɾɾ͡Ό͋Զ ͕ΔΑɻ</button> </p> </div> EBUBมͷʹԠͯ͡ ϦΞΫςΟϒʹද͕ࣔ Γସ͑ΒΕΔ
࣮ߦ͢Δͱ
ΫϥεͱελΠϧͷόΠϯσΟϯά σβΠϯ͢Δ࣌ʹඞཁͱͳΓ·͢
WCJOEσΟϨΫςΟϒ ΫϥεελΠϧΛಈతʹΓସ͑Δ͜ͱ͕ग़དྷ·͢ɻ <div class=“static" v-bind:class="{ ‘class-a’: isA, ‘class-b’: isB }">
ΫϥεͱελΠϧͷόΠϯσΟϯά // main.js new Vue({ el: '#app', data: { isEvening:
false } }); <style type="text/css"> html, body { padding: 0px; margin: 0px; height: 100%; } .container { width: 100%; height: 100%; } .orange { background-color: orange; } </style> <div id=“app" class=“container" v-bind:class="{ orange: isEvening }"> <button v-on:click="isEvening = true”> ༦ম͚ʹ͢Δ </button> <button v-on:click="isEvening = false”> ݩʹ͢ </button> </div> ΫϥεͷόΠϯσΟϯάઃఆ
ϒϥβදࣔ݁Ռ
Ϋϥε͕Ճ͞ΕΔ
ίϯϙʔωϯτ ಠࣗͷλά͕࡞ΕΔڧྗػೳ
ίϯϙʔωϯτ w࠶ར༻ՄೳͳίʔυͷΧϓηϧԽ͕ग़དྷ·͢ <div id="app"> <header-component></header-component> {{ message }} <footer-component></footer-component> </div>
<div id="app"> <div id=“header”>ϔομʔؔ࿈ͷ͍ιʔείʔυ</div> {{ message }} <div id=“footer”>ϑολʔؔ࿈ͷ͍ιʔείʔυ</div> </div>
ίϯϙʔωϯτ // main.js Vue.component('header-component', { template: '<h1>phpcon 2016</h1>' }); Vue.component('footer-component',
{ template: '<div>\ <hr>\ <center>All Rights Reserved.</center>\ </div>' }); new Vue({ el: '#app', data: { message: '?> NEXT' } }); // index.html <div id="app"> <header-component></header-component> {{ message }} <footer-component></footer-component> </div>
ϒϥβදࣔ݁Ռ
7VFKTͷҙ ͕ࣗϋϚͬͨ͜ͱͰ͢
ϋϚͬͨՕॴ ϏϧυϑΝΠϧ͕̎छྨ͋Δ
CSPXTFSJGZFTSDKTNBJOKTPQVCMJDBQQKTΛ࣮ߦʂ // src/js/main.js var Vue = require('vue'); new Vue({ el:
'#app', data: { message: 'Hello PHP Confference 2016!' } }); // index.html <div id="app"> <div> {{ message }} </div> </div> <script type="text/javascript" src="app.js"></script>
ϒϥβͰݟΔͱ UFNQMBUFຢSFOEFSϑΝϯΫγϣϯ͕ఆٛ͞Ε͍ͯͳ͍ͱ ౖΒΕͯ͠·͏ɾɾɾɾ
ϏϧυϑΝΠϧ͕̎ͭ͋Δ w͔Β̎ͭʹ͔Εͨ wελϯυΞϩϯ൛ɿ)5.-ίϯύΠϥଂɺ7VFYܥͱಉ͡ɻ wϥϯλΠϜݶఆϏϧυ൛ɿ)5.-ίϯύΠϥແ͠ɻOQNͰσϑΥ ϧτͰͪ͜ΒΛग़ྗɻ
ճආํ๏ެ͔ࣜΒఏࣔ͞Ε͍ͯΔ
BMJBTJGZͰSFRVJSF࣌ʹελϯυΞϩϯ൛Λ༻͢ΔΑ͏ʹௐ { "scripts": { "build": "browserify -e src/js/main.js -o public/app.js"
}, "browserify": { "transform": [ "aliasify" ] }, "aliasify": { "aliases": { "vue": "vue/dist/vue.js" } }, "dependencies": { "vue": "^2.0.3" }, "devDependencies": { "aliasify": "^2.0.0" } } ͕͜͜ϙΠϯτʂ
࠶Ϗϧυ͢͠ͱΤϥʔແ͘දࣔ͞Ε·͢
جຊจ๏͔͚ͬͨͲɺ Ͳ͜Ͱใऩू͢Ε͍͍ͷ͔ʁ
ใݯ wຊޠެࣜαΠτ wIUUQTKQWVFKTPSH w7VFKTೖʕ࠷Ͱ࡞Δγϯϓϧͳ8FCΞϓ Ϧέʔγϣϯ IUUQHJIZPKQEFWTFSJBMWVFKT
7VFKTίϛϡχςΟ͕͋Γ·͢ʂ
7VFKTίϛϡχςΟ w4MBDLίϛϡχςΟWVFKTKQ wIUUQTWVFKTKQTMBDLJOIFSPLVBQQDPN w7VFKT.FFUVQ wIUUQWVFKTNFFUVQDPOOQBTTDPN
7VFKTͷະདྷ
ͷ৽ػೳ wੑೳ w3FOEFSؔ wαʔόʔαΠυϨϯμϦϯά wαϙʔτϥΠϒϥϦ wίϛϡχςΟϓϩδΣΫτ IUUQTKQWVFKTPSHIFSF
αʔόʔαΠυϨϯμϦϯά
αʔόʔαΠυϨϯμϦϯά ൪ʹϦΫΤετ αʔόʔαΠυϨϯμϦϯά Ϩεϙϯε wจࣈ௨ΓαʔόʔαΠυଆͰ)5.-ΛϨϯμϦϯάͯ͠ฦ͢
αʔόʔαΠυϨϯμϦϯάͷඞཁੑ w4&0ରࡦ wΫϩʔϥʔͷ"KBYʹΑΔඇಉظίϯςϯπ ͷΠϯσοΫεରࡦ wߴԽ wॳظϩʔυ࣌ؒͷॖ
αϯϓϧίʔυΛݟͯΈΑ͏
αʔόʔαΠυϨϯμϦϯάͷϙΠϯτᶃ var renderer = require(‘vue-server-renderer').createRenderer() wWVFTFSWFSSFOEFSFS7VFKT͚αʔόʔαΠ υϨϯμϦϯάOQNύοέʔδ wDSFBUF3FOEFSFSϝιουͰSFOEFSFSΠϯελϯεΛ ੜ
αʔόʔαΠυϨϯμϦϯάͷϙΠϯτᶄ renderer.renderToString(ViewModelObject, callback) w7VFͷ7JFX.PEFMΦϒδΣΫτ͔Β)5.-Λੜ͢ Δؔɻ w)5.-จࣈྻͷੜ݁Ռ͕ίʔϧόοΫͰ͞ΕΔɻ
̏ϑΝΠϧ༻ҙ͠·͢ wJOEFYIUNM w ςϯϓϨʔτϑΝΠϧ wBTTFUTBQQKT w 7VFKTએݴ෦ wTFSWFSKT w αʔόʔαΠυΤϯτϦʔϙΠϯτ
w &YQSFTTͰ)551αʔόʔએݴ
JOEFYIUNM <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>My Vue App</title> </head> <body> <div id="app"></div> <script type="text/javascript" src="assets/app.js"></script> </body> </html> ۭͷ)5.-Λ४උ
BTTFUTBQQKT module.exports = function () { return new Vue({ template:
'<div id="app">Hello PHP Confference{{ year }}!</div>', data: { year: 2016 } }) }
TFSWFSKT 'use strict' var fs = require('fs') var path =
require('path') // αʔόαΠυͰར༻͢ΔͨΊɺάϩʔόϧมʹ Vue Λ ఆٛ͢Δ global.Vue = require('vue') var layout = fs.readFileSync('./index.html', 'utf8') var renderer = require('vue-server- renderer').createRenderer() var express = require('express') var server = express() // assets σΟϨΫτϦ੩తʹϑΝΠϧΛసૹ͢Δɻ server.use('/assets', express.static( path.resolve(__dirname, 'assets') )) server.get('/', function (request, response) { renderer.renderToString( require('./assets/app')(), function (error, html) { response.send(layout.replace('<div id="app"></div>', html)) } ) }) // 5000൪ϙʔτͰػ server.listen(5000, function (error) { if (error) throw error console.log('Server is running at localhost: 5000') }) ςϯϓϨϑΝΠϧΛಡΈࠐΉ
TFSWFSKT 'use strict' var fs = require('fs') var path =
require('path') // αʔόαΠυͰར༻͢ΔͨΊɺάϩʔόϧมʹ Vue Λ ఆٛ͢Δ global.Vue = require('vue') var layout = fs.readFileSync('./index.html', 'utf8') var renderer = require('vue-server- renderer').createRenderer() var express = require('express') var server = express() // assets σΟϨΫτϦ੩తʹϑΝΠϧΛసૹ͢Δɻ server.use('/assets', express.static( path.resolve(__dirname, 'assets') )) server.get('/', function (request, response) { renderer.renderToString( require('./assets/app')(), function (error, html) { response.send(layout.replace('<div id="app"></div>', html)) } ) }) // 5000൪ϙʔτͰػ server.listen(5000, function (error) { if (error) throw error console.log('Server is running at localhost: 5000') }) SFOEFSFS FYQSFTTΠϯελϯεΛੜ
TFSWFSKT 'use strict' var fs = require('fs') var path =
require('path') // αʔόαΠυͰར༻͢ΔͨΊɺάϩʔόϧมʹ Vue Λ ఆٛ͢Δ global.Vue = require('vue') var layout = fs.readFileSync('./index.html', 'utf8') var renderer = require('vue-server- renderer').createRenderer() var express = require('express') var server = express() // assets σΟϨΫτϦ੩తʹϑΝΠϧΛసૹ͢Δɻ server.use('/assets', express.static( path.resolve(__dirname, 'assets') )) server.get('/', function (request, response) { renderer.renderToString( require('./assets/app')(), function (error, html) { response.send(layout.replace('<div id="app"></div>', html)) } ) }) // 5000൪ϙʔτͰػ server.listen(5000, function (error) { if (error) throw error console.log('Server is running at localhost: 5000') }) ᶃɹͷϦΫΤετΛड͚Δ
TFSWFSKT 'use strict' var fs = require('fs') var path =
require('path') // αʔόαΠυͰར༻͢ΔͨΊɺάϩʔόϧมʹ Vue Λ ఆٛ͢Δ global.Vue = require('vue') var layout = fs.readFileSync('./index.html', 'utf8') var renderer = require('vue-server- renderer').createRenderer() var express = require('express') var server = express() // assets σΟϨΫτϦ੩తʹϑΝΠϧΛసૹ͢Δɻ server.use('/assets', express.static( path.resolve(__dirname, 'assets') )) server.get('/', function (request, response) { renderer.renderToString( require('./assets/app')(), function (error, html) { response.send(layout.replace('<div id="app"></div>', html)) } ) }) // 5000൪ϙʔτͰػ server.listen(5000, function (error) { if (error) throw error console.log('Server is running at localhost: 5000') }) ᶄBTTFUTBQQKTΛ)5.-ม
TFSWFSKT 'use strict' var fs = require('fs') var path =
require('path') // αʔόαΠυͰར༻͢ΔͨΊɺάϩʔόϧมʹ Vue Λ ఆٛ͢Δ global.Vue = require('vue') var layout = fs.readFileSync('./index.html', 'utf8') var renderer = require('vue-server- renderer').createRenderer() var express = require('express') var server = express() // assets σΟϨΫτϦ੩తʹϑΝΠϧΛసૹ͢Δɻ server.use('/assets', express.static( path.resolve(__dirname, 'assets') )) server.get('/', function (request, response) { renderer.renderToString( require('./assets/app')(), function (error, html) { response.send(layout.replace('<div id="app"></div>', html)) } ) }) // 5000൪ϙʔτͰػ server.listen(5000, function (error) { if (error) throw error console.log('Server is running at localhost: 5000') }) ᶅϨεϙϯεͰฦ͢
ςϯϓϨʔτϑΝΠϧͷҰ෦ͱஔ <div id="app" server-rendered="true">Hello, PHP Confference 2016!</div> layout.replace('<div id="app"></div>', html)
SFOEFS5P4USJOHͷίʔϧόοΫ͔Βฦͬͯ͘ΔIUNMͷத ϨΠΞτશମͷςϯϓϨϑΝΠϧͷҰ෦ͱஔ͖͑
ϒϥβͰදࣔ͢Δͱ
7VFKT͕αʔόʔ͔ΒϨϯμϦϯά͞ΕͯฦΔ αʔόʔαΠυϨϯμϦϯά͞Ε͍ͯΔʂʂʂ
ײ wਖ਼ͳॴ·ͩ·ͩෆ໌ଟ͍ wαʔόʔαΠυϨϯμϦϯάͷҰൠతͳඞཁੑཧղͰ͖Δ w443Λར༻࣮ͯ͢͠Δʹίετ͕͔͔ΔͷͰɺαʔϏεͷಛੑ ඞཁੑΛཧղ্͍ͨ͠Ͱબ͢Δඞཁ͕͋Δ
࠷ޙʹ·ͱΊͰ͢
·ͱΊ wجૅΛ֮͑Ε͙͢ʹίʔυΛॻ͚ͯಈ͖͕ग़ͤΔͷͰ໘ന͍ʂ w֤छϚχϡΞϧ͕ຊޠͰ༻ҙ͞Ε͍ͯΔͷͰɺڵຯͷ͋ΔํΨΠ υΛಡΜͰΈΔ͜ͱΛΦεεϝ͠·͢ w·ͩ·ͩࣗ7VFKTษڧதͰ͋ΓཧղͰ͖͍ͯͳ͍ͷͰɺҾ ͖ଓ͖Ξτϓοτ͍͖ͯ͠·͢ɻ
༧ࠂ ˞7VFKTͷίʔυωʔϜ&WBOHFMJPO
:"1$)PLLBJEP 4BU ʮ7VFKT쎂쎟쎢8FC쎬쏡쏴쎻썗쏁쏱쏽։ൃʯ
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠ʂ