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
JavaScript も jQuery も未経験の新人エンジニアが 1 年間 Vue.js を...
Search
yugkwmt
November 01, 2019
Programming
1
1.8k
JavaScript も jQuery も未経験の新人エンジニアが 1 年間 Vue.js を 学習して感じた話 / frontend conference 2019
yugkwmt
November 01, 2019
Tweet
Share
More Decks by yugkwmt
See All by yugkwmt
テスト稼働の削減とフロントエンドの品質担保を行うE2Eテスト
yugkwmt
3
1.9k
Laravel バージョンアップと品質担保の話
yugkwmt
2
560
Other Decks in Programming
See All in Programming
Оптимизируем производительность блока Казначейство
lamodatech
0
960
Fibonacci Function Gallery - Part 2
philipschwarz
PRO
0
210
ASP.NET Core の OpenAPIサポート
h455h1
0
120
watsonx.ai Dojo #6 継続的なAIアプリ開発と展開
oniak3ibm
PRO
0
170
Асинхронность неизбежна: как мы проектировали сервис уведомлений
lamodatech
0
1.4k
Fixstars高速化コンテスト2024準優勝解法
eijirou
0
190
asdf-ecspresso作って 友達が増えた話 / Fujiwara Tech Conference 2025
koluku
0
1.4k
非ブラウザランタイムとWeb標準 / Non-Browser Runtimes and Web Standards
petamoriken
0
430
ESLintプラグインを使用してCDKのセオリーを適用する
yamanashi_ren01
2
240
はてなにおけるfujiwara-wareの活用やecspressoのCI/CD構成 / Fujiwara Tech Conference 2025
cohalz
3
2.8k
盆栽転じて家具となる / Bonsai and Furnitures
aereal
0
1.9k
ChatGPT とつくる PHP で OS 実装
memory1994
PRO
3
190
Featured
See All Featured
What’s in a name? Adding method to the madness
productmarketing
PRO
22
3.2k
Designing on Purpose - Digital PM Summit 2013
jponch
116
7.1k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
6
500
Bootstrapping a Software Product
garrettdimon
PRO
305
110k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
26
1.9k
Scaling GitHub
holman
459
140k
A Philosophy of Restraint
colly
203
16k
We Have a Design System, Now What?
morganepeng
51
7.3k
Fantastic passwords and where to find them - at NoRuKo
philnash
50
2.9k
A Modern Web Designer's Workflow
chriscoyier
693
190k
Typedesign – Prime Four
hannesfritz
40
2.5k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
251
21k
Transcript
JavaScript も jQuery も未経験の新人エ ンジニアが 1 年間 Vue.js を 学習して感じた話
株式会社ラクス 川又 由雅 FRONTEND CONFERENCE 2019
自己紹介 • 川又 由雅 • 株式会社ラクス • 業務で経験した言語 ◦ PHP(Laravel)
◦ HTML, CSS ◦ JavaScript, jQuery, Vue.js • Chat Dealerの開発に携わっている 2
定期的に勉強会を開催中! 3 https://rakus.connpass.com/
この発表のターゲット • これから Vue.js を学び始める人 ◦ 勉強法、つまづいたときの解決法など • Vue.js を教える人
◦ Vue.jsを初めて学ぶ人がどこにつまづくか、解決さ せるにはどうすればよいか 4
目次 • Vue.js との出会い • Vue.js の学習方法 • 開発業務で Vue.js
を使ってみて苦労したこと • Vue.js と jQuery を使いこなせるようになってきて • これから Vue.js を学び始める人へ • まとめ 5
Vue.js との出会い 6
Vue.js とは? • 2014 年にリリースされた JavaScript のフレームワーク • 2015 年には
PHP のフレームワーク「Laravel」のフロン トエンドエンジンに採用され、知名度が上昇 • Adobe や任天堂、LINE など有名な企業で広く採用され ている 7
Vue.js とは? • JavaScript のデータを更新するだけで描画されている 内容も更新される(データバインディング) • 一度作ったリソースの再利用を得意としている(コン ポーネント) 8
Vue.js を触ったきっかけ • 研修で Vue.js の学習を行った ◦ 配属された部署で開発している「Chat Dealer」はフ ロントエンドに
Vue.js や jQuery が用いられている 9
Chat Dealer とは? • サイトに専用スクリプトを埋め込んで利用するチャットシ ステム 10
Chat Dealer で Vue.js を使うところ • 管理画面 11
Vue.js の学習 12
Vue.js の勉強の流れ まずは教科書を読む • 「基礎から学ぶ Vue.js」mio 著 • Vue.js がどんなものなのか知る
• サンプルコードが豊富 • Vue.js について詳しく書かれている 13
Vue.js の勉強の流れ Web 上でコードを書いてみる(JSFiddle) • 公式ドキュメントを読みながら書いてみる • 教科書のサンプルコードを読みながら書いてみる • ちゃんと説明通り動くか確認
• https://jsfiddle.net/ 14
15
Vue.js に対して感じたこと • 機能が豊富 ◦ データバインディング ◦ v-if(分岐) ◦ v-for(繰り返し)
...etc • 記述がシンプル ◦ データ、メソッドの構成がわかりやすい 16
便利な機能 • データバインディング ◦ データを更新するだけで描画内容が更新される ◦ 入力内容をプレビューとして表示するときに変更が すぐ反映されて便利 ◦ 入力してすぐに描画内容が変わったことに驚いた
17
18 ここでデータバ インディングを 行う 使用する データ
便利な機能 19
便利な機能 • v-if ◦ 入力内容によって表示⇔非表示を変える ◦ ブロックの表示⇔非表示を簡単に切り替えられて 便利 ◦ データとv-ifを使うだけでブロックの表示⇔非表示を
切り替えられて驚いた 20
21 表示⇔非表示 の判定を行う 使用するデータ
22 isShow == trueのとき isShow == falseのとき
便利な機能 • v-for ◦ 配列として格納しているデータの中身を繰り返し描 画する ◦ 簡単に配列の中身をループすることができてうれし い ◦
繰り返し処理の記述の簡単さに驚いた 23
24 使用する配列 リストで配列 の中身を繰り 返し描画
25 実行結果
シンプルな記述 • 構成に関してどこに何を書くべきかわかりやすい ◦ データ(data) ◦ メソッド(methods) 26
開発業務で Vue.js を 使ってみて苦労したこと 27
コンポーネント • 開発中のコードで、設定したデータがどう動いているか 理解するのに苦労した ◦ コードの量が多くて整理しづらかった →デバッグを用いてデータの流れをメモしながら整 理する 28
コンポーネント • 教科書を読んでもなかなかコンポーネントを理解できな かった →教科書をじっくり読んで理解できないときは先輩 に聞く 29
イベントハンドラ • イベントハンドラ:ボタンをクリックしてアラートを出すな ど処理を行う 30
31 使用するイベントハ ンドラ(ボタンをク リックすると発動) 「data中のname (“Vue.js”)」とイベント を起こしたタグの名 前(button)をアラート で表示
イベントハンドラ • 引数に入れる「event」をどう使えばよいかわからな かった →不明点を先輩に教えてもらった Web上のサンプルコードや教則動画を見てみる 32
Vue.js と jQuery を 使いこなせるように なってきて 33
jQuery に対する所感 • Vue.js と違って使用する範囲を指定しないのは自由に 書けていい ◦ Vue.js で使用する範囲がかぶるとエラーになる 34
35 かぶると エラーが 発生
jQuery に対する所感 • class, id による検索など構文の書き方が面倒 ◦ Vue.js は使いたい要素に書けばよいが、jQuery は
class, id から検索する ◦ 運用も Vue.js の方が楽に感じる 36
jQuery に対する所感 • jQuery 37 class 名を検索
• Vue.js jQuery に対する所感 38 要素を直接指定
Vue.jsに対する所感 • 機能が豊富で多くのことが実現できてうれしい ◦ for 文による繰り返し ◦ if 文による分岐処理 ...etc
• 記述がシンプルで理解しやすい • 半年から1年にかけてコンポーネントがスラスラ書ける ようになり、理解が深まったことを実感した 39
比較してどう感じたか • Vue.js のほうが書き方がシンプルに感じた ◦ v-for のように配列を用いた繰り返しが簡単に書け て良い ◦ v-if
のように表示⇔非表示が簡単に書けて良い ◦ 対象の要素に直接書き込んで使えて良い • Vue.jsは使用する範囲を指定するところが面倒 40
これから Vue.js を 学び始める人へ 41
おすすめの Vue.js の学習法 1. サンプルコードを記述して実行 ◦ 公式ドキュメント、教科書を参照する →実際に書いてみることで知識が定着する ◦ 業務で教科書の「4章:データの加工と監視」のゲッ
ター、セッターは非常に役に立った 42
おすすめの Vue.js の学習法 2. 学習したことを取り入れたページを作ってみる ◦ TODOリスト →学んだことをどう使うか考えるのでより理解が深 まる 43
まとめ 44
まとめ 45 • 公式ドキュメントなど日本語のドキュメントが豊富で学 習しやすかった • 記述がシンプルで理解しやすかった
まとめ 46 • コンポーネントは導入は難しいが理解できれば便利で うれしい • jQuery と比較して記述がシンプルで良い • 理解を深めるならサンプルコードを書くだけでなく、学
習したことを取り入れたページを作成してみるのも良い
まとめ 47 • Vue.jsの内容で理解が不足しているポイントがないか 探して、もう1度学び直したい • 自分でページを作ってみたい ◦ TODO リスト
◦ チャットアプリ ...etc