wepy--vantUIでアップグレードリストを実現し、対応する値を選択して操作する。
vantUIは多く紹介していません。比較的に使いやすいuiコンポーネントライブラリです。以下は住所です。自分で見てみてください。
https://youzan.github.io/vant/#/zh-CN/actionse heet
次に私達は直接に本題に入ります。このデモの中で、このポップアップ層を一つのコンポーネントにカプセル化して、定義されたページで呼び出すために、まずやるべきことは一つのページを定義して、一つのコンポーネントを定義することです。以下はコードです。
これは選択されていない場合です。
選択時:
北京大学をクリックした後:
最後の提出:提出時のパラメータ:
以上は簡単に見て、層デモをイジェクトしました。
補足知識:vantUIのskyuコンポーネントの使用(カスタムヒント情報を追加し、カスタムボタンでskyuの選択値を取得する)
最近作ったモバイルエレクト事業者のプロジェクトは、vantUIの開発が便利なので、最後にvantUIとvueを使って開発を結合することにしました。skyコンポーネントを使う時に問題が発生しました。まず、skyuを使った効果図を見てみます。
設計図をもう一度見てみます。
明らかにヒントが足りません。スロットを書いて実現すればいいです。
最後に最終効果を見ます。
追加:
選択した規格を取得する方法
1、まずラベルにref属性を追加します。
2、規格取得が必要なイベントでは、直接にthis.$refs.(refの属性値).(公式提供のget SkuDataメソッド)を使って取得すればいいです。
コードの例は以下の通りです
印刷結果:
以上のwepyはvantUIでアップグレードリストを実現し、それに応じた値操作を選択します。つまり、小編集は皆さんに共有しています。参考にしてもらいたいです。どうぞよろしくお願いします。
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でアップグレードリストを実現し、それに応じた値操作を選択します。つまり、小編集は皆さんに共有しています。参考にしてもらいたいです。どうぞよろしくお願いします。