ホームページ  >  記事  >  ウェブフロントエンド  >  Vue を使用して PopupWindow コンポーネントを実装する方法

Vue を使用して PopupWindow コンポーネントを実装する方法

php中世界最好的语言
php中世界最好的语言オリジナル
2018-06-01 14:54:052058ブラウズ

今回は、Vue を使用して PopupWindow コンポーネントを実装する方法を説明します。Vue を使用して PopupWindow コンポーネントを実装する場合の注意事項について説明します。

私はこの期間中、自分自身の小さなプロジェクトを完了するためにフロントエンドテクノロジーを学習してきました。 js の場合は、Vue フレームワークが使用されます。プロジェクト内の新しいアドレスの PopupWindow 効果を実現したかったので、Vue のいくつかの機能を使用してそれを実現できると考えました。

使用される Vue 機能: コンポーネント、プロパティ

値転送、スロット コンテンツの挿入、トランジション トランジション アニメーション、X テンプレート テンプレート。

コードに直接移動します (完全なコードはリンクのポップアップウィンドウでダウンロードできます):

html コード (スタイルなし):

<p id="address-choose">
 <p>
 <button @click="showOneBtnWindow()">显示</button>
  </p>
  <new-address-window 
   v-show="isShowEditWindow" 
   @close="removeEditWindow()" 
   :addressregion="addressRegion">
   <!--使用插槽显示不同的title-->
   <p slot="edit-window-title">
   {{editTitle}}
   </p>
   <p slot="popup-btn-container">
   <button>保存</button> 
   <button>删除</button>
  </p>
  </new-address-window>
 </p>
<!--新建地址popupwindow模板-->
<script type="text/x-template" id="popup-window-address-new">
 <transition name="popup-window-transition">
 <p>
  <slot name="edit-window-title">
  <p>新建收货地址</p>
  </slot> 
 </p>
 <p>
 <p>收货人</p>
 <input type="text" :value="addressregion.name"/>
 </p>
 <p>
 <p>选择地区</p>
 <ul>
  <li>{{addressregion.province}}</li>
  <li>{{addressregion.city}}</li>
  <li>{{addressregion.region}}</li>
 </ul>
 </p>
 <p>
 <p>联系电话</p>
 <input type="text" placeholder="手机号"/>
 </p>
 <p>
  <p>详细地址</p>
  <input type="text" placeholder="如街道、楼层、门牌号等"/>
 </p>
 <p>
 <p>邮政编码</p>
 <input type="text" placeholder="邮政编码(选填)"/>
 </p>
 <p>
 <slot name="popup-btn-container">
  <button class="btn btn-success">保存</button>
  <button class="btn btn-danger">删除</button>
 </slot>
 </p>
 </p>
 </transition>
</script>
js コード:

/*
 * 新建与编辑地址Vue组件popupwindow
 * */
var newAddressWindow = Vue.component("new-address-window",{
 props: ['addressregion'],
 template: "#popup-window-address-new"
})
/*
 * 地址popupwindow的Vue实例
 * */
var chooseAddress = new Vue({
 el: "#address-choose",
 data: {
 isShowEditWindow: true,
 isOneButton: false,
 editTitle: "新建收货地址",
 //填入初始地址信息,组件与改数据绑定
 addressRegion: {
 }
 },
 methods: {
 showOneBtnWindow: function(){ //显示新建收货地址对话框(有一个按钮)
  this.isShowEditWindow = true;
  this.isOneButton = false;
  this.editTitle = "新建收货地址";
 },
 removeEditWindow: function(){ //关闭新建与编辑地址选择对话框
  this.isShowEditWindow = false;
 }
 }
})
この時点で、popupwindow コンポーネントが完成します。 Vue コンポーネントを実装するときは、テンプレートを使用してコンポーネントを実装することができます。同時に、vue のトランジション機能を使用してコンポーネントにアニメーション効果を追加することもできます。 。

この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨書籍:

電子時計効果を実現するための jQuery の操作方法

Vue nextTick の使用方法

以上がVue を使用して PopupWindow コンポーネントを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。