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
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
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
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
200
TAKTでAI駆動開発の品質を設計する
j5ik2o
6
1.2k
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
160
AI駆動開発で崩れていくコードベースを立て直す
kyoko_nr_nr
1
450
New "Type" system on PicoRuby
pocke
1
830
Inside Stream API
skrb
1
680
例外の正しい扱い方 そのエラー try-catchして大丈夫?
jinwatanabe
0
210
Oxcを導入して開発体験が向上した話
yug1224
4
310
Why Laravel apps break—Mastering the fundamentals to keep them maintainable
kentaroutakeda
1
350
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
20
6.5k
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
150
依存関係から依存物へ―Dependencyという言葉の歴史をひも解く
j_lee
0
110
Featured
See All Featured
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
360
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
160
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.7k
Bash Introduction
62gerente
615
220k
How to Talk to Developers About Accessibility
jct
2
230
It's Worth the Effort
3n
188
29k
A Modern Web Designer's Workflow
chriscoyier
698
190k
30 Presentation Tips
portentint
PRO
1
320
Darren the Foodie - Storyboard
khoart
PRO
3
3.4k
brightonSEO & MeasureFest 2025 - Christian Goodrich - Winning strategies for Black Friday CRO & PPC
cargoodrich
3
730
Navigating Algorithm Shifts & AI Overviews - #SMXNext
aleyda
1
1.3k
Writing Fast Ruby
sferik
630
63k
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쎬쏡쏴쎻썗쏁쏱쏽։ൃʯ
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠ʂ