TIS ENGINEER NOTE

27才文系出身フリーランスエンジニアのブログ

プログラミング

シンプルな構成から学ぶVue.jsのコンポーネント

更新日:

今ノリに乗っているjavascriptフレームワーク『Vue.js』

Vue.jsを利用するなら是非とも身に付けたいコンポーネントを使った構成について、今回は超簡易的なソースコードを例に挙げて解説していこうと思います。

概要

今回は非常に簡易的なログイン画面のようなものを作ってみます。

あとはComponent間のデータの受け渡しを把握しやすくするために、入力中の値をリアルタイムで表示する機能も実装します。

入力フォームに値を入力し、送信ボタンを押すことでサーバーにデータを送信し登録する形になります。

サーバー側は送信されたemailをユーザーテーブルに登録するという処理を行なっていますが、今回は関連性が薄いため説明は省略します。

最終的に出来上がるページはこんな感じ。無骨ですね。

ログイン前

ログイン後

ソース

HTML

この後紹介するjavascriptソースで作成するカスタム要素を中心にして記述しています。

javascript

基本的には親要素である、main-flameのIDを保持するdiv要素を経由させて入力フォーム、プレビュー箇所のデータのやりとりを行なっていくイメージです。ちなみにformタグを使用していないため、一般的な登録画面とは異なりますが、説明の便宜上このような構成を取っております。

以下でもうちょっと細かく見ていきます。

メインフレーム(親要素)

まずは

  • 入力フォーム
  • 送信ボタン
  • プレビュー表示箇所

を内包する親要素です。

こちらはVue.jsを使い始めると紹介される一番ベーシックな書き方で定義しています。

el要素にコンポーネントを包み込むためのdivタグのidを記載します。これによって指定したdivタグ配下の要素が以下の処理の管理下に置かれるイメージです。

dataはこのメインフレーム内で扱うデータを定義しています。例えばemailであれば、このデータを元に入力フォームのデータをプレビュー表示箇所に受け渡しなりを行うために用意しています。

で、最後にmethodsですが、こちらは名前の通り実行する処理を書いていきます。上で説明したようなフォームの入力の保持であったりサーバーとの通信を行う処理を記述しています。

emailValueでは引数として渡された値(inEmail)をdataで用意したemailに代入します。

sendEmailではdataのemailの値をサーバーにPOSTする処理を行なっています。転送が成功した場合、表示制御に使っているloginをtrueに設定しています。これによって、Welcome!が表示されるようになります。

ここで宣言されているメソッドは子要素から呼び出されて処理を開始します。呼び出し方などの詳細は子要素の方で解説します。

入力フォーム

次は入力フォーム部分のコンポーネントです。

子要素は全てComponent形式で利用していきます。

templateには実際に描画するためのHTMLタグを記述します。

v-on:input="emailInput"によって、値が入力された時にmethodsで宣言しているemailInputが実行されます。

v-model="inemail"ではdateにあるinemailを入力フォームの値に紐付けています。

dataの記述の仕方がメインフレームの時と異なりますが、Componentではdataは関数である必要があるため、このように記述しています。

methodsemailInputの内容がちょっとわかりにくいのですが、一旦HTMlのemail-inputを見てみてください。

email-inputタグにおいて@input-email="emailValue"とありますが、これは親要素であるフレームワーク内で用意されている関数であるemailValueをinput-emailという要素に結びつけています。

あとはmailInputの$emitにinput-emailを渡したい引数と共に渡すことで親要素のemailValueコールされます。

この$emitは親要素のイベントを発火させるためのメソッドです。

上で説明済みですが、親要素では引数に渡された入力フォームに入力された値を自身のdataにセットしているわけです。

ここでセットした値がプレビュー表示やボタン押下時のサーバー通信に利用されることとなります。

プレビュー表示

次に入力した値がリアルタイムで表示させるプレビュー表示部分の処理です。

わかりやすいようにHTMLファイルの記述も再度載せておきます。

ここではそこまでややこしいことはやっておりませんが、HTMLのカスタム要素が少しわかりづらいかもしれません。

templateでは入力フォームの時と同じように、画面に表示される際のHTMLタグを記述しています。今回はpタグの中に{{ disemail }}と記述されることで、javascriptで処理された値を表示するようにしています。

表示させる値はpropsで宣言されている値です。このpropsは親要素からデータを受け取り、値が変化することになります・

HTMLの方でv-bindを利用して、propsに親要素で宣言されているdata、emailをセットしているのが確認できると思います。

送信ボタン

最後のコンポーネントである送信ボタンです。

そしてこちらが対応するHTMLのコード。

基本的にやっていることは入力フォームと同じで、emitを使って親要素のイベントを発火しています。

ボタンをクリックすることで、

  • 送信ボタンコンポーネントのcreateUserが呼ばれ
  • その中で親要素のsendEmailが呼び出され
  • axiosを利用したサーバー通信が行われる

といった流れになります。

まとめ

いかがだったでしょうか。親子関係においてどのようにデータが流れ、イベントが動き出すのか、ということがイメージできればそこまで難しくないことかと思います。

もし今回の投稿で不明な点、うまく行かない点などあれば、twitterや問い合わせから質問を投げてもらえればできる限りの対応をさせていただきます。

Vue.jsには単一ファイルコンポーネントという面白そうなアプローチもありますので、そちらについても取り組んでみて共有できればなと思います。

Vue.jsはこれからもどんどん盛り上がっていき、需要も増えるフレームワークでしょう。是非一度触ってみてください。

閲覧いただき、ありがとうございました。

よく読まれている記事

エンジニア独立

2018/8/12

SIer・SESからWEB系エンジニアにキャリアチェンジする現実的な方法

エクセルで作らされる誰が読むかも分からないドキュメント 月に1回の帰社日 枯れた技術を言われた通りに扱うだけの毎日 スーツ勤務で下級労働者扱い SIer・SES系エンジニアとしての業務経験があり、かつ外の世界を知ったエンジニアから見たSIer・SES系のイメージってこんな感じですよね。 ここで言う外の世界の代表格と言えばWEB系ベンチャーやフリーランス。 カテゴライズの厳密さについては色々と意見はありますが、いわゆる自社サービスで利益を立てている企業と言えば分かりやすいでしょう。 最近ではエンジニアの待遇 ...

続きを読む

エンジニア独立

2018/8/17

プログラマーの働き方比較【正社員 vs 派遣 vs フリーランス】

最近ではエンジニアの需要が激増し、特にプログラマーを目指す人が増えてきました。 今の時代、プログラマーを目指すというのはかなり賢い選択です。1年ちょっとの現場経験を積めばあっという間にサラリーマンの平均年収を超えることが可能です。 その一方で、世間ではプログラマーの不遇が叫ばれていたり、IT土方などの蔑称で呼ばれていたりします。 それは働き方の選択を誤っているプログラマーがあまりに多いことが原因となっています。 稼げる市場であるということは、依頼主と技術提供者の間の利益を掻っ攫おうとするハイエナが多く存在 ...

続きを読む

エンジニア入門

2018/8/17

現役エンジニアからみたProEngineerの『エンジニアカレッジ』について

こんにちは、フリーエンジニアのてぃすです。 最近、 どうすればエンジニアになれるのか エンジニアになるためにどんな勉強をしたの? といった質問を受けることが多くなってきました。 エンジニアは高稼働のブラック職業であるという印象も薄れてきて、効率よく稼げる職業としての側面に気付き始めた方が増えてきたということでしょう。 とはいえ全くの未経験からITエンジニアに転向するというのは独学の場合、不可能ではありませんが、かなり難易度の高い挑戦であると言えます。たとえ独学で成し遂げたとしても、よっぽど運がよくない限り ...

続きを読む

エンジニア入門

2018/8/19

本気でRubyを学びたい人のためのエンジニアスクール『ポテパンキャンプ』

こんにちは、フリーエンジニアのてぃすです。 エンジニアといえば今や最も少ない投資で高収入を望め、更には週3勤務やリモートワークなどの柔軟な働き方も目指せる夢のある職業です。 ここ最近は営業職や事務職から、将来性を考えてエンジニアに転身するといういう人もかなり増えてきています。 特にRubyプログラマーは日本における絶大な需要とリモート案件の豊富さから、特に人気のあるポジションとなっています。エンジニアとして働いているが、職場環境に不満を抱いていたり、今扱っている技術が今後通用するか不安に感じ、Ruby・W ...

続きを読む

エンジニア入門

2018/8/19

最も効率の良いプログラミング学習フロー

こんにちは、フリーエンジニアのてぃすです。 エンジニアの需要が拡大し、売り手市場となったことから、プログラミングを学習し始めた人、学習してみたいという人がかなり増えてきています。 これからの時代プログラミングを学習することは、豊かな人生を目指す上で非常に強力なスキルとなってきます。 今回はプログラミング初心者の方々に向けて、最も効率的なプログラミングの学習方法を解説していきます。 はじめに この学習フローでは、遊びのメカニズムを利用して進めていきます。 どういうことでしょうか。説明していきます。 遊ぶ感覚 ...

続きを読む

-プログラミング
-,

Copyright© TIS ENGINEER NOTE , 2018 All Rights Reserved Powered by AFFINGER5.