0%

Programmingプログラミングナレッジ

Posted:2018.06.29

Vue.jsで双方向データバインドを使ったサンプル

フロントエンドの実装で注目されているjavascriptフレームワーク「Vue.js」を使うと、双方向のデータバインディングが簡単に実現できます。この双方向データバインディングで、HTMLのビュー側で持つ値と、javascriptのモデル側で持つ値の同期ができるようになります。

 

今回はVue.jsで実装された双方向のデータバインドの例として、フォーム項目を使ってまとめていきたいと思います。

 

1. フォーム入力テキストの同期

インプット項目に入力されたテキストをそのまま画面上に出力します。入力されたタイミングで同期されるようになります。

【HTML(ビュー)】※一部省略

<div id="app_01">
  <form>
    <input type="text" v-model="obj">
  </form>
  <p>:フォームの内容は「{{ obj }}」です
  </p>
</div>

 

【javascript(モデル)】

var app = new Vue({
  el: '#app_01',
  data: {
    obj: ''
  }
});

 

 

2. 入力値チェック(ラジオボタン)

複数の単一選択(ラジオボタン)でチェックが入った値を出力します。こちらも入力されたタイミングで同期されます。

【HTML(ビュー)】※一部省略

<div id="app_2">
  <form>
    <label for="radio_01">選択肢1</label><input type="radio" id="radio_01" value="選択肢1" v-model="input_radio">
    <label for="radio_02">選択肢2</label><input type="radio" id="radio_02" value="選択肢2" v-model="input_radio">
    <label for="radio_03">選択肢3</label><input type="radio" id="radio_03" value="選択肢3" v-model="input_radio">
  </form>
  <p>:選択されているのは「{{ input_radio }}」です
  </p>
</div>

 

【javascript(モデル)】

var app = new Vue({
  el: '#app_02',
  data: {
    input_radio: '選択肢1'
  }
});

 

 

3. 入力値チェック(チェックボックス)

チェックボックスでチェックが入っているかどうかを同期することでリアルタイムで確認することができます。

【HTML(ビュー)】※一部省略

<div id="app_03">
  <form>
    <label for="check_01">チェックする</label><input type="checkbox" id="check_01" v-model="input_check" true-value="チェックされています" false-value="チェックされていません">
  </form>
  <p>:{{input_check}}
  </p>
</div>

 

【javascript(モデル)】

var app = new Vue({
  el: '#app_03',
  data: {
    input_check: 'チェックされていません'
  }
});

 

 

4. 入力値チェック(セレクトボックス)

複数の選択肢で選択された項目の値を出力させます。こちらも選択されたタイミングで値を同期して表示させることができます。

【HTML(ビュー)】※一部省略

<div id="app_04">
  <form>
    <select v-model="input_select">
      <option value="">選んでください</option>
      <option>オレンジ</option>
      <option>アップル</option>
      <option>グレープ</option>
    </select>
  </form>
<p>:選んだフルーツは「{{input_select}}」です
</p>
</div>

 

【javascript(モデル)】

var app = new Vue({
  el: '#app_04',
  data: {
    input_select: ''
  }
});

 


 

これらはあくまで基本的な形ですが、双方向データバインドの形をだいたい理解できるのではないでしょうか。使い方によってはいろんな機能を実現できそうですね。今回のサンプルはこちらに上げておりますので、実際に確認することができます。

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】