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
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.6k
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.9k
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
Agentic UI
manfredsteyer
PRO
0
160
AIだと陥りがちなJakarta EE最新技術への移行時の落とし穴と解決策
tnagao7
0
110
セキュリティの専門家じゃなくてもできる。「セキュリティ意識」をアップデートして サプライチェーン攻撃への耐性を高めよう。
tk3fftk
5
760
net-httpのHTTP/2対応について
naruse
0
480
Spec Driven Development | AI Summit Lisbon
danielsogl
PRO
0
190
Language Server 使ってる? 〜VSCode と Zed の場合〜 / Are you using a Language Server? ~For VS Code and Zed~
handlename
0
780
Mujeres en SEO Summit 2026 - Greatest Disaster Hits en Web Performance
guaca
0
180
さぁV100、メモリをお食べ・・・
nilpe
0
140
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
540
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
12k
ECSアプリログをFireLensでコスト削減しようとしたけど諦めた話 in Fargate×Node.js
akihisaikeda
2
4.2k
不変条件と整合性境界—ビジネスが決める設計判断と実現パターン / Invariants and Consistency Boundaries
nrslib
13
4.5k
Featured
See All Featured
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
430
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.3k
Digital Ethics as a Driver of Design Innovation
axbom
PRO
1
310
[SF Ruby Conf 2025] Rails X
palkan
2
1.1k
Designing Powerful Visuals for Engaging Learning
tmiket
1
410
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
250
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.8k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
Building an army of robots
kneath
306
46k
Documentation Writing (for coders)
carmenintech
77
5.4k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
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쎬쏡쏴쎻썗쏁쏱쏽։ൃʯ
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠ʂ