Submit Search
Upload
Vue.jsで遊んでみよう
•
2 likes
•
601 views
シ
シオリ ショウノ
Follow
2017/6/22 v-osakaの登壇資料です。 超初心者におすすめ。
Read less
Read more
Software
Report
Share
Report
Share
1 of 28
Download now
Download to read offline
Recommended
もくもくと過ごした2016年振り返り
もくもくと過ごした2016年振り返り
Erina Takei
フリーランスミートアップを開催してきた@Creators MeetUp #44
フリーランスミートアップを開催してきた@Creators MeetUp #44
Erina Takei
オープンソースプロジェクトのはじめかた@Creators MeetUp #25
オープンソースプロジェクトのはじめかた@Creators MeetUp #25
Erina Takei
Javascript を使ってみよう!!
Javascript を使ってみよう!!
誠 小林
GUIツールで送る快適な Gitライフ@Creators MeetUp #29
GUIツールで送る快適な Gitライフ@Creators MeetUp #29
Erina Takei
VSハッカソン TypeScript ハンズオン
VSハッカソン TypeScript ハンズオン
Kazuhide Maruyama
【再放送】生放送の前にJQueryについて復習しよう!
【再放送】生放送の前にJQueryについて復習しよう!
schoowebcampus
concrete5を体験する会
concrete5を体験する会
Fumito Mizuno
Recommended
もくもくと過ごした2016年振り返り
もくもくと過ごした2016年振り返り
Erina Takei
フリーランスミートアップを開催してきた@Creators MeetUp #44
フリーランスミートアップを開催してきた@Creators MeetUp #44
Erina Takei
オープンソースプロジェクトのはじめかた@Creators MeetUp #25
オープンソースプロジェクトのはじめかた@Creators MeetUp #25
Erina Takei
Javascript を使ってみよう!!
Javascript を使ってみよう!!
誠 小林
GUIツールで送る快適な Gitライフ@Creators MeetUp #29
GUIツールで送る快適な Gitライフ@Creators MeetUp #29
Erina Takei
VSハッカソン TypeScript ハンズオン
VSハッカソン TypeScript ハンズオン
Kazuhide Maruyama
【再放送】生放送の前にJQueryについて復習しよう!
【再放送】生放送の前にJQueryについて復習しよう!
schoowebcampus
concrete5を体験する会
concrete5を体験する会
Fumito Mizuno
冬合宿でOpenProcessing
冬合宿でOpenProcessing
yusuketomioka
はじめてのWord pressプラグイン勉強会
はじめてのWord pressプラグイン勉強会
Takahiro Nakahata
コードをさわらずにビジネスサイトを作ろう!
コードをさわらずにビジネスサイトを作ろう!
FLOW web planning & design
Node.jsでサーバプログラマ デビューしよう
Node.jsでサーバプログラマ デビューしよう
Yuusuke Takeuchi
「できるサイボウズLive」
「できるサイボウズLive」
cybozu live
Live dekiru low
Live dekiru low
Mizuki Tanno
iPhone開発者初心者向け資料「XcodeのStoryboardで画面を作ろう!」
iPhone開発者初心者向け資料「XcodeのStoryboardで画面を作ろう!」
Toshio Ehara
Lt 110416
Lt 110416
Tomoyuki Obi
2012.11.03 #odstudy Excel方眼紙に魂を削られない為のoffice講座
2012.11.03 #odstudy Excel方眼紙に魂を削られない為のoffice講座
真乙 九龍
HSPでおいしいスープを飲む方法
HSPでおいしいスープを飲む方法
Hiroaki Murayama
Saitowotsukutsutemita
Saitowotsukutsutemita
hmatumoto
Css nite(2010.09.23)
Css nite(2010.09.23)
Yoshiki Ushida
NCstudy 2.5
NCstudy 2.5
Yuichi Saotome
初めてのvue.js(2.x系)
初めてのvue.js(2.x系)
健人 井関
MetroStyleAppsさわってみた わんくま
MetroStyleAppsさわってみた わんくま
c-mitsuba
LightSwitch で遊んでみた Rev. 2
LightSwitch で遊んでみた Rev. 2
Yoshitaka Seo
プログラミング講座 #3 コードを書く
プログラミング講座 #3 コードを書く
ZOIdayo
Dxライブラリテンプレート作成のすすめ
Dxライブラリテンプレート作成のすすめ
Umebosi
introduction to Marionette.js (jscafe14)
introduction to Marionette.js (jscafe14)
Ryuma Tsukano
Swiftビギナーズ倶楽部 vol.2
Swiftビギナーズ倶楽部 vol.2
Kanako Kobayashi
Notificationsを使ったSlack通知
Notificationsを使ったSlack通知
シオリ ショウノ
肌で感じたディレクションとマネジメント
肌で感じたディレクションとマネジメント
シオリ ショウノ
More Related Content
Similar to Vue.jsで遊んでみよう
冬合宿でOpenProcessing
冬合宿でOpenProcessing
yusuketomioka
はじめてのWord pressプラグイン勉強会
はじめてのWord pressプラグイン勉強会
Takahiro Nakahata
コードをさわらずにビジネスサイトを作ろう!
コードをさわらずにビジネスサイトを作ろう!
FLOW web planning & design
Node.jsでサーバプログラマ デビューしよう
Node.jsでサーバプログラマ デビューしよう
Yuusuke Takeuchi
「できるサイボウズLive」
「できるサイボウズLive」
cybozu live
Live dekiru low
Live dekiru low
Mizuki Tanno
iPhone開発者初心者向け資料「XcodeのStoryboardで画面を作ろう!」
iPhone開発者初心者向け資料「XcodeのStoryboardで画面を作ろう!」
Toshio Ehara
Lt 110416
Lt 110416
Tomoyuki Obi
2012.11.03 #odstudy Excel方眼紙に魂を削られない為のoffice講座
2012.11.03 #odstudy Excel方眼紙に魂を削られない為のoffice講座
真乙 九龍
HSPでおいしいスープを飲む方法
HSPでおいしいスープを飲む方法
Hiroaki Murayama
Saitowotsukutsutemita
Saitowotsukutsutemita
hmatumoto
Css nite(2010.09.23)
Css nite(2010.09.23)
Yoshiki Ushida
NCstudy 2.5
NCstudy 2.5
Yuichi Saotome
初めてのvue.js(2.x系)
初めてのvue.js(2.x系)
健人 井関
MetroStyleAppsさわってみた わんくま
MetroStyleAppsさわってみた わんくま
c-mitsuba
LightSwitch で遊んでみた Rev. 2
LightSwitch で遊んでみた Rev. 2
Yoshitaka Seo
プログラミング講座 #3 コードを書く
プログラミング講座 #3 コードを書く
ZOIdayo
Dxライブラリテンプレート作成のすすめ
Dxライブラリテンプレート作成のすすめ
Umebosi
introduction to Marionette.js (jscafe14)
introduction to Marionette.js (jscafe14)
Ryuma Tsukano
Swiftビギナーズ倶楽部 vol.2
Swiftビギナーズ倶楽部 vol.2
Kanako Kobayashi
Similar to Vue.jsで遊んでみよう
(20)
冬合宿でOpenProcessing
冬合宿でOpenProcessing
はじめてのWord pressプラグイン勉強会
はじめてのWord pressプラグイン勉強会
コードをさわらずにビジネスサイトを作ろう!
コードをさわらずにビジネスサイトを作ろう!
Node.jsでサーバプログラマ デビューしよう
Node.jsでサーバプログラマ デビューしよう
「できるサイボウズLive」
「できるサイボウズLive」
Live dekiru low
Live dekiru low
iPhone開発者初心者向け資料「XcodeのStoryboardで画面を作ろう!」
iPhone開発者初心者向け資料「XcodeのStoryboardで画面を作ろう!」
Lt 110416
Lt 110416
2012.11.03 #odstudy Excel方眼紙に魂を削られない為のoffice講座
2012.11.03 #odstudy Excel方眼紙に魂を削られない為のoffice講座
HSPでおいしいスープを飲む方法
HSPでおいしいスープを飲む方法
Saitowotsukutsutemita
Saitowotsukutsutemita
Css nite(2010.09.23)
Css nite(2010.09.23)
NCstudy 2.5
NCstudy 2.5
初めてのvue.js(2.x系)
初めてのvue.js(2.x系)
MetroStyleAppsさわってみた わんくま
MetroStyleAppsさわってみた わんくま
LightSwitch で遊んでみた Rev. 2
LightSwitch で遊んでみた Rev. 2
プログラミング講座 #3 コードを書く
プログラミング講座 #3 コードを書く
Dxライブラリテンプレート作成のすすめ
Dxライブラリテンプレート作成のすすめ
introduction to Marionette.js (jscafe14)
introduction to Marionette.js (jscafe14)
Swiftビギナーズ倶楽部 vol.2
Swiftビギナーズ倶楽部 vol.2
More from シオリ ショウノ
Notificationsを使ったSlack通知
Notificationsを使ったSlack通知
シオリ ショウノ
肌で感じたディレクションとマネジメント
肌で感じたディレクションとマネジメント
シオリ ショウノ
PHPカンファレンス関西2017 スポンサー募集中!
PHPカンファレンス関西2017 スポンサー募集中!
シオリ ショウノ
Gulpで学ぶSassとPug
Gulpで学ぶSassとPug
シオリ ショウノ
ハンズオン入門
ハンズオン入門
シオリ ショウノ
ServiceとRepository
ServiceとRepository
シオリ ショウノ
Laravel 5.3 で basic task list を作ろう!
Laravel 5.3 で basic task list を作ろう!
シオリ ショウノ
Webpackにトライ 基本編
Webpackにトライ 基本編
シオリ ショウノ
Carbonライブラリとちゃんと向き合ってみる
Carbonライブラリとちゃんと向き合ってみる
シオリ ショウノ
Laravelの5.3の新機能
Laravelの5.3の新機能
シオリ ショウノ
20160422 laravel.osaka
20160422 laravel.osaka
シオリ ショウノ
More from シオリ ショウノ
(11)
Notificationsを使ったSlack通知
Notificationsを使ったSlack通知
肌で感じたディレクションとマネジメント
肌で感じたディレクションとマネジメント
PHPカンファレンス関西2017 スポンサー募集中!
PHPカンファレンス関西2017 スポンサー募集中!
Gulpで学ぶSassとPug
Gulpで学ぶSassとPug
ハンズオン入門
ハンズオン入門
ServiceとRepository
ServiceとRepository
Laravel 5.3 で basic task list を作ろう!
Laravel 5.3 で basic task list を作ろう!
Webpackにトライ 基本編
Webpackにトライ 基本編
Carbonライブラリとちゃんと向き合ってみる
Carbonライブラリとちゃんと向き合ってみる
Laravelの5.3の新機能
Laravelの5.3の新機能
20160422 laravel.osaka
20160422 laravel.osaka
Vue.jsで遊んでみよう
1.
Vue.js で遊んでみよう
2.
自己紹介 ショウノシオリ @shosho_egg ・株式会社 chatbox
エンジニア ・フロントやったり、 PHPやったり ・Laravel と Vue.js で管理画面を作ったりしています ・Qiita:shosho
3.
アジェンダ ▷ 0. Vue.js
とは? ▷ 1. 準備をしよう ○ インストール ▷ 2. 「Hello Vue!」を表示する ○ 基本的なVueの記法 ▷ 3. ボタンを押してメッセージを変えよう ○ methodsで関数を登録 ○ @click で関数を呼び出す ▷ 4. フォーム値をリアルタイムで出力してみよう ○ 双方向バインディング v-model ▷ 5. 最初にアラートを出してみよう ○ created ○ ライフサイクルダイアグラム
4.
0. Vue.js とは?
5.
初心者でも触りやすいJSフレームワーク ▷ 「少しずつ始められて、柔軟に使えるJSフレームワーク」 といった感じ ○ 「見た目」と「データ」を分けて記述
するので、「見た目だけの変更」など に対応しやすい ○ モノリシックなフレームワークではなく、部分的に利用可能 ▷ 最新 ver. は 2.x ▷ ドキュメントが充実 ○ 英語 https://vuejs.org/ ○ 日本語 https://jp.vuejs.org/
6.
シンプルなので組み合わせて使うとよい◎ ▷ APIを叩いたりはできないので、他のライブラリなどを利 用する ○ superagent
を利用したり ○ データをごっそりAPI経由で送れるので、Laravel のBladeと組み合わ せて使ってみたりしてます
7.
1. 準備
8.
準備をしよう ▷ ドキュメント通りにすればOK ○ 日本語ドキュメント https://jp.vuejs.org/v2/guide/installation.html ▷
開発 / 本番モードがあるので注意
9.
2. 「Hello Vue!」
10.
$(()=>{ var app =
new Vue({ el : ‘#app’, data : { message: ‘Hello Vue!’ } }); }); ▷ 動かし方:new Vue({...}) と書く ▷ 適用範囲:el で指定 ○ el がないと動かない ○ 今回は id で指定したが、クラス指定でも動く ▷ データの記述場所:data 「Hello Vue!」を表示する(JS側)
11.
<div id=”app”> <p>{{ message
}}</p> </div> ▷ {{ message }} でデータバインディングができる ▷ el の指定を忘れないこと 「Hello Vue!」を表示する(HTML側)
12.
結果 ▷ ブラウザに「Hello Vue!」と出力される
13.
3. クリックイベント
14.
data : { message:
‘Hello Vue!’ }, methods : { changeMessage(){ this.message = ‘How are you?’; } } ▷ 関数を登録:methods ○ this.message で登録した data にアクセスできる ○ changeMessage 関数を呼び出すと this.message を違うメッ セージで代入 ボタンを押してメッセージを変えよう(JS側)
15.
<div id=”app”> <p>{{ message
}}</p> <button @click=”changeMessage”>click Here!!</button> </div> ▷ @click でイベントが発動する ○ ボタンが押されると methods の changeMessage が実行される ▷ @click は v-on:click の略 ボタンを押してメッセージを変えよう(HTML側)
16.
結果 ▷ 変わります
17.
4. 双方向バインディング
18.
▷ 双方向バインディング:v-model ○ フォームの値を動的に取得することができる ▷
データが双方向でバインディング(紐付け)されるため、フォーム値を 変更すると、{{ comment }} 内もリアルタイムで変わる フォーム値をリアルタイムで出力してみよう (HTML側) <input type=”text” v-model=”comment”/> <p>確認:{{ comment }}</p>
19.
▷ JS側で v-model
の登録を忘れずに ○ data で登録 ○ 初期値が必要(今回は空の ‘’ で) ○ 登録していないと {{ comment }} がテキストとして認識される フォーム値をリアルタイムで出力してみよう (JS側) data : { message: ‘Hello Vue!’, comment: ‘’ },
20.
結果 ▷ 入力フォームに入れた値が「確認」の右横に表示される ○ 入力値を変えると表示されるメッセージも変わる
21.
5. ライフサイクルダイアグラム
22.
▷ ブラウザを最初に読み込んだ時にアラート表示を実行 ▷ Vue
生成時に呼ぶ:created ○ created が呼ばれた時にはまだ data の中身は読み込まれない 最初にアラートを出してみよう(JS側) methods : { changeMessage(){ this.message = ‘How are you?’; } }, created(){ alert(‘Vue.jsをはじめよう!’); }
23.
ライフサイクルダイアグラム ▷ https://jp.vuejs.org/v2/guide/instance.html#ライフサイクルダイアグ ラム ○ observe
data:データがあるのか等のチェックはするが、まだデー タは埋め込まれない ○ createdの時点にはまだ data が入らない ○ 赤字:イベント ○ 実践:否が応でも進む方向 ○ 点線:場合によって待ったりする方向 ○ mountされる:データがはめ込まれる ○ destroy:コンポーネントとかを読み終わったら。
24.
結果 ▷ created が呼び出された段階ではまだ
data が呼び出されていないので {{ message }} {{ comment }} のようになっている
25.
他にもよく使うもの ▷ v-if ▷ v-for ▷
componentに分けたり
26.
Vue.js でつくりたいもの ▷ 個人的に
Vue.js で作っていた「持ち物アプリ」を完成 させたい ○ SPAっぽいやつ
27.
Qiita記事 ▷ Vue.js をちょっと使ってみる http://qiita.com/shosho/items/38273d099a41acd341c2 ▷
Vueにデバッグ関数を追加 http://qiita.com/shosho/items/7960293de6c6663a5a37 ▷ Vue.js の「ライフサイクルダイアグラム」の見方 http://qiita.com/shosho/items/8a6692e773eb8175498a ▷ Vue.js のデータバインディングとレンダリング http://qiita.com/shosho/items/d2889b2e806d6a756d70 ▷ Vue.js の v-if をつけるとき http://qiita.com/shosho/items/7fa3235ff9cc2dc7b6db
28.
Thanks! Any questions? You can
find me at: @username user@mail.me
Download now