wepy--vantUIでアップグレードリストを実現し、対応する値を選択して操作する。


vantUIは多く紹介していません。比較的に使いやすいuiコンポーネントライブラリです。以下は住所です。自分で見てみてください。
https://youzan.github.io/vant/#/zh-CN/actionse heet
次に私達は直接に本題に入ります。このデモの中で、このポップアップ層を一つのコンポーネントにカプセル化して、定義されたページで呼び出すために、まずやるべきことは一つのページを定義して、一つのコンポーネントを定義することです。以下はコードです。

<template>
 <view class="container">
  <image src="{{localUser.avatarUrl}}" class="backimg" mode="aspectFill">
   <view class='backimg' style='position:absolute;top:0;height:300rpx;width:100%;'></view>
  </image>
  <view class="touxiang_area">
   <view class="touxiang_view">
    <image src="{{localUser.avatarUrl}}" catchtap="changePic"></image>
   </view>
   <view class='touxiang-text'>
    <text catchtap="changeName" class='name'>{{localUser.nickName}}</text>
   </view>
  </view>
  <view style="margin-top:125px;">
   <van-cell-group>
    <block wx:if="{{saLogined}}">
     <van-cell title="     " icon="add-o" >
         
     </van-cell>
    </block>
    <block wx:else>
     <van-cell title="     " icon="add-o" url="/pages/authPage" is-link>
     </van-cell>
    </block>
 
    <van-cell title="  " icon="edit"></van-cell>
   </van-cell-group>
  </view>
  <view class="body">
   <form bindsubmit="formSubmit">
    <view class="message messageTwo">
     <view class="label">  </view>
     <input placeholder="         " placeholder-class="place" name="realName" value="{{realName}}"
         confirm-type="done" />
    </view>
    <view class="message messageThree">
     <view class="label">  </view>
     <input placeholder="       " placeholder-class="place" name="phone" value="{{phone}}" confirm-type="done" />
    </view>
//      vant  cellGroup
//cell           group   ,       :
//CellGroup   Cell                             
//title                   
//value                         
// location: {
 //    id: -1,
 //    name: '   '
 //  },
 
//             
//@tap          。         invoke             
    <van-cell-group>
     <van-cell
      title="    "
      is-link
      value="{{location.name}}"
      @tap="popup"
     >
     </van-cell>
     </van-cell-group>
 //       ,                 
    <bolck>
 
     <button form-type='submit' class="submit">{{submit ? '    ': '  '}}</button>
    </bolck>
   </form>
  </view>
  
 </view>
//                      showPopup          
//setLocationId               
 
//                                                
//       
 <chooseSchoolPopup :show.sync="showPopup" v-on:setLocationId="setLocationId">
 
 </chooseSchoolPopup>
</template>
<script>
 import wepy from 'wepy';
 
 import {
  SYSTEM_INFO,
  USER_INFO,
  TOKEN
 } from '@/utils/constant';
//request                
 import { request } from '../utils/util';
//         ,              
 import chooseSchoolPopup from '../components/chooseSchoolPopup';
//    page       
 export default class UserInfo extends wepy.page {
//               
  components = {
   chooseSchoolPopup: chooseSchoolPopup,
  };
//            
  data = {
   active: 4,
   localUser: {},
   saLogined: false,
   phone: '',
   realName: '',
   submit: false,
   location: {
    id: -1,
    name: '   '
   },
   showPopup: true,
   location_id:null
  };
//             ,          ui      
//        ,           ,             
  config = {
   navigationBarTitleText: '  ',
   usingComponents: {
    'van-cell': '../components/van/cell/index',
    'van-cell-group': '../components/van/cell-group/index',
    'van-row': '../components/van/row/index',
    'van-col': '../components/van/col/index',
    'van-field': '../components/van/field/index',
    'van-popup': '../components/van/popup/index',
   }
  };
//   onshow                 ,      
  async onShow(){
   let servant = await request('/servant/getSelfInfo');
   this.saLogined = servant.saLogined;
   this.location = servant.location;
   console.log('user onShow', servant);
   this.$apply();
  }
//onload                     
  async onLoad() {
   let user = wepy.getStorageSync(USER_INFO);
   this.localUser = user;
   try {
    let servant = await request('/servant/getSelfInfo');
    console.log('user onLoad', servant);
    this.realName = servant.realName;
    this.phone = servant.phone;
    this.location = servant.location ? servant.location.name : null;
    this.saLogined = servant.saLogined;
    this.$apply();
 
   } catch (e) {
    console.error(e);
   }
  }
 
  //            
  methods = {
//                  ,                 
//          ,            
//             ,        this.$apply();         
   setLocationId(e){
    console.log('setLocationId',e)
    this.location_id =e.id
    this.location = e
   },
//                 ,          
//    invoke   ,
//                 ,    ,            ,
//                   ,             
//              ,               
   popup() {
    this.$invoke('chooseSchoolPopup', 'onPopup');
   },
//      form         
   async formSubmit(e) {
    var value = e.detail.value;
    console.log('formSubmit', e.detail);
    var params = {
     realName: value.realName,
//  id              
     location_id: this.location_id,
     phone: value.phone
    };
    console.log('formSubmit',params)
//             
    try {
     await request('/servant/emdit/self', {
      method: 'POST',
      data: params
     });
     this.submit = true;
     this.$apply();
    } catch (e) {
     console.log(e);
    }
   }
 
  };
 }
</script>
//            less  
<style lang="less">
//         ,        
 @import "../style/global";
 
 .body {
  background: white;
  .message {
   margin-top: 10px;
   display: flex;
   width: 100%;
   height: 100px;
   align-items: center;
   border-bottom: 1px solid #e8e8e8;
   justify-content: space-between;
  }
  .label {
   color: #333;
   margin-left: 20px;
   font-size: @font-size-normal;
  }
  .messageOne {
   image {
    height: 80px;
    width: 120px;
    margin-right: 20px;
    /*border-radius: 50%;*/
   }
  }
  input {
   padding-left: 20px;
   /*flex: 1;*/
   color: #333;
   font-size: @font-size-normal;
   text-align: right;
   margin-right: 20px;
   width: 80%;
  }
  .submit {
   position: fixed;
   bottom: 20px;
   left: 36px;
   width: 90%;
   background-color: #ea3333;
   color: #fff;
  }
 }
 
 .container {
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  overflow-x: hidden;
  overflow-y: hidden;
 }
 
 .backimg {
  height: 250px;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0.95) 40%, rgba(255, 255, 255, 1) 98%, #FFFFFF 100%);
  overflow: hidden;
  position: absolute;
  top: 0;
  width: 100%;
 }
 
 .touxiang_area {
  height: 250px;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
  border-bottom: 10px solid #e7e7eb;
  width: 100%;
  vertical-align: middle;
  position: absolute;
 }
 
 .touxiang_view {
  display: inline-block;
  width: 35%;
 }
 
 .touxiang_view > image {
  width: 130px;
  height: 130px;
  border-radius: 100%;
  margin-top: 25%;
  margin-left: 25%;
 }
 
 .touxiang-text {
  display: inline-block;
  width: 400px;
  position: absolute;
  top: 40%;
  /* line-height: 60rpx; */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
 }
 
 .touxiang-text > text {
  font-size: 32px;
 }
 
 .touxiang_area > text {
  margin-top: 20px;
 }
 
 .city {
  /* margin-top:10rpx; */
  padding-bottom: 15px;
  font-size: 30px;
 }
 
 .city > text {
  font-size: 30px;
 }
 
 .name {
  overflow: hidden;
  width: 250px;
  display: inline-block;
  -webkit-line-clamp: 1;
  text-overflow: ellipsis;
  white-space: nowrap;
 }
 
 button::after {
  border: none;
 }
 
 input {
  outline: none;
  border: none;
  list-style: none;
 
 }
</style>

以上はページとその属性方法を定義するコードです。以下、該当するコンポーネントのコードを見てみます。

<template>
//          
//showPopup                 
//onclose            
//position          
 <van-popup show="{{ showPopup }}" bind:close="onPopup" position="bottom">
  <van-radio-group value="{{ lastSchool.id }}">
   <van-cell-group>
//          
    <repeat for="{{ locationList }}">
//                                 ,         item
//    
     <van-cell title="{{item.name}}" clickable @tap="onClick({{item}})">
      <van-radio name="{{item.id}}" >
      </van-radio>
     </van-cell>
    </repeat>
   </van-cell-group>
 
  </van-radio-group>
 </van-popup>
</template>
 
<script>
 
 import wepy from 'wepy';
//   component        
 export default class myTabBar extends wepy.component {
// props            ,                ,            
  props = {
   lastSchool: {
    type: Object,
    twoWay: true
   }
  };
//data     ,               
  data = {
   showPopup: false,
   locationList: []
  };
 
  onLoad() {
 
//                       
//                    
   let locationList = wepy.getStorageSync('locationList');
   console.log('popup load');
   if (locationList) {
    this.locationList = locationList;
   }
  }
  methods = {
//                           ,  showPopup      ,    
//       
   onPopup(event) {
    console.log('close', event);
    this.showPopup = !this.showPopup;
   },
//               
//     emit                         ,       ,      
//               
   onClick(item, e) {
    console.log('item', item, e);
    this.lastSchool = item;
    this.$emit('setLocationId', item);
    this.showPopup = !this.showPopup;
   },
     };
 };
</script>
//           
<style lang="less">
 @import "../style/global";
 .van-radio__icon--checked{
  color:@theme-color !important;
 }
</style>

いくつかの効果図を見てみましょう。
これは選択されていない場合です。

選択時:

北京大学をクリックした後:

最後の提出:提出時のパラメータ:

以上は簡単に見て、層デモをイジェクトしました。
補足知識:vantUIのskyuコンポーネントの使用(カスタムヒント情報を追加し、カスタムボタンでskyuの選択値を取得する)
最近作ったモバイルエレクト事業者のプロジェクトは、vantUIの開発が便利なので、最後にvantUIとvueを使って開発を結合することにしました。skyコンポーネントを使う時に問題が発生しました。まず、skyuを使った効果図を見てみます。

設計図をもう一度見てみます。

明らかにヒントが足りません。スロットを書いて実現すればいいです。

最後に最終効果を見ます。

追加:
選択した規格を取得する方法
1、まずラベルにref属性を追加します。

2、規格取得が必要なイベントでは、直接にthis.$refs.(refの属性値).(公式提供のget SkuDataメソッド)を使って取得すればいいです。

コードの例は以下の通りです

印刷結果:

以上のwepyはvantUIでアップグレードリストを実現し、それに応じた値操作を選択します。つまり、小編集は皆さんに共有しています。参考にしてもらいたいです。どうぞよろしくお願いします。