aosiyiliaouniapp/components/QuShe-picker/QuShe-picker.vue

890 lines
27 KiB
Vue
Raw Normal View History

2024-04-08 02:59:47 +00:00
<template>
<view :style="{'z-index': zIndex}" @touchmove.prevent.stop="voidFc()" @tap.prevent.stop="voidFc()">
<view
class="mask"
:class="showPicker?'show':'hide'"
:style="{'z-index': Number(zIndex) + 1}"
@touchmove.prevent.stop="voidFc()"
@tap.prevent.stop="hide()"></view>
<view
class="flex_column"
:class="[mode||'middle', showPicker?'show':'hide']"
:style="'z-index:' + (Number(zIndex) + 2) + ';'"
@touchmove.prevent.stop="voidFc()"
@tap.prevent.stop="voidFc()">
<view class="flex_column" :class="(mode||'middle') + '_view'" :style="{'height': heightSize}">
<block v-if="mode==='bottom'">
<view class="flex_row_between_c width100 padding20rpx" :style="{'font-size': titleSize, 'background-color': bgColor_title||'#f8f8f8'}">
<view class="flex_row_none_c width250rpx " :style="{'color': buttonSet.cancleColor||'#ADADAD'}" @tap="hide()">
{{buttonSet.cancleName||'取消'}}
</view>
<view class="flex_row_c_c width250rpx" :style="{'color': titleColor||'#999'}">
{{title||''}}
</view>
<view class="flex_row_e_c width250rpx" :style="{'color': buttonSet.confirmColor||'#3399FF'}" @tap="confirm()">
{{buttonSet.confirmName||'确定'}}
</view>
</view>
</block>
<block v-else-if="mode==='middle'">
<view class="flex_row_c_c width100 padding20rpx" :style="{'font-size': titleSize, 'background-color': bgColor_title||'#f8f8f8', 'color': titleColor||'#999'}" v-if="title">
{{title||''}}
</view>
</block>
<picker-view :indicator-style="'height:' + wH*(lineHeight||.09) + 'px;' + indicator_style" class="width100 height100 backgroundColor_white" :style="{'font-size': contentSize, 'color': contentColor||'black'}" :value="value" @change="bindChange($event)">
<block v-if="type==='date'">
<picker-view-column v-if="setObj.dateMode>=1">
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in years" :key="picker_index">{{picker_item}}</view>
</picker-view-column>
<picker-view-column v-if="setObj.dateMode>=2">
<!-- #ifndef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 12" :key="picker_index">{{picker_item+1}}</view>
<!-- #endif -->
<!-- #ifdef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 12" :key="picker_index">{{picker_item}}</view>
<!-- #endif -->
</picker-view-column>
<picker-view-column v-if="setObj.dateMode>=3">
<!-- #ifndef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in days" :key="picker_index">{{picker_item+1}}</view>
<!-- #endif -->
<!-- #ifdef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in days" :key="picker_index">{{picker_item}}</view>
<!-- #endif -->
</picker-view-column>
<picker-view-column v-if="setObj.dateMode>=4">
<!-- #ifndef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 24" :key="picker_index">{{picker_item}}</view>
<!-- #endif -->
<!-- #ifdef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 24" :key="picker_index">{{picker_item-1}}</view>
<!-- #endif -->
</picker-view-column>
<picker-view-column v-if="setObj.dateMode>=5">
<!-- #ifndef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 60" :key="picker_index">{{picker_item}}</view>
<!-- #endif -->
<!-- #ifdef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 60" :key="picker_index">{{picker_item-1}}</view>
<!-- #endif -->
</picker-view-column>
<picker-view-column v-if="setObj.dateMode>=6">
<!-- #ifndef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 60" :key="picker_index">{{picker_item}}</view>
<!-- #endif -->
<!-- #ifdef H5 -->
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in 60" :key="picker_index">{{picker_item-1}}</view>
<!-- #endif -->
</picker-view-column>
</block>
<block v-else-if="type==='city'">
<picker-view-column>
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in provinceDataList" :key="picker_index">{{picker_item.label}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in cityDataList" :key="picker_index">{{picker_item.label}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in areaDataList" :key="picker_index">{{picker_item.label}}</view>
</picker-view-column>
</block>
<block v-else-if="type==='provincialStreet'">
<picker-view-column>
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in provinceDataList" :key="picker_index">{{picker_item.label}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in cityDataList" :key="picker_index">{{picker_item.label}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in areaDataList" :key="picker_index">{{picker_item.label}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(picker_item,picker_index) in streetDataList" :key="picker_index">{{picker_item}}</view>
</picker-view-column>
</block>
<block v-if="type==='custom'">
<block v-if="setObj.linkage">
<block v-if="setObj.linkageNum===2">
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemArray" :key="index">{{item[setObj.steps.step_1_value]}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemArray[value[0]][setObj.steps.step_2_item]" :key="index">{{item[setObj.steps.step_2_value]||item}}</view>
</picker-view-column>
</block>
<block v-else-if="setObj.linkageNum===3">
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemArray" :key="index">{{item[setObj.steps.step_1_value]}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemArray[value[0]][setObj.steps.step_2_item]" :key="index">{{item[setObj.steps.step_2_value]}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemArray[value[0]][setObj.steps.step_2_item][value[1]][setObj.steps.step_3_item]"
:key="index">{{item[setObj.steps.step_3_value]||item}}</view>
</picker-view-column>
</block>
</block>
<block v-else>
<picker-view-column v-for="(items, indexs) in setObj.itemArray" :key="indexs">
<view class="flex_row_c_c" v-for="(item, index) in items" :key="index">{{setObj.steps?setObj.steps.step_1_value?item[setObj.steps.step_1_value]:item:item}}</view>
</picker-view-column>
</block>
</block>
<block v-if="type==='custom2'">
<block v-if="setObj.linkage">
<block v-if="setObj.linkageNum===2">
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemObject.step_1" :key="index">{{setObj.steps.step_1_value?item[setObj.steps.step_1_value]:item}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemObject.step_2[value[0]]" :key="index">{{setObj.steps.step_2_value?item[setObj.steps.step_2_value]:item}}</view>
</picker-view-column>
</block>
<block v-else-if="setObj.linkageNum===3">
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemObject.step_1" :key="index">{{setObj.steps.step_1_value?item[setObj.steps.step_1_value]:item}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemObject.step_2[value[0]]" :key="index">{{setObj.steps.step_2_value?item[setObj.steps.step_2_value]:item}}</view>
</picker-view-column>
<picker-view-column>
<view class="flex_row_c_c" v-for="(item,index) in setObj.itemObject.step_3[value[0]][value[1]]" :key="index">{{setObj.steps.step_3_value?item[setObj.steps.step_3_value]:item}}</view>
</picker-view-column>
</block>
</block>
<block v-else>
<picker-view-column v-for="(items, indexs) in setObj.itemArray" :key="indexs">
<view class="flex_row_c_c" v-for="(item, index) in items" :key="index">{{setObj.steps.step_1_value?item[setObj.steps.step_1_value]:item}}</view>
</picker-view-column>
</block>
</block>
</picker-view>
<block v-if="mode==='top'">
<view class="flex_row_between_c width100 padding20rpx" :style="{'font-size': titleSize, 'background-color': bgColor_title||'#f8f8f8'}">
<view class="flex_row_none_c width250rpx " :style="{'color': buttonSet.cancleColor||'#ADADAD'}" @tap="hide()">
{{buttonSet.cancleName||'取消'}}
</view>
<view class="flex_row_c_c width250rpx" :style="{'color': titleColor||'#999'}">
{{title||''}}
</view>
<view class="flex_row_e_c width250rpx" :style="{'color': buttonSet.confirmColor||'#3399FF'}" @tap="confirm()">
{{buttonSet.confirmName||'确定'}}
</view>
</view>
</block>
</view>
<view class="flex_row" style="margin-top: 20px;" v-if="mode==='middle'">
<view class="flex_row_c_c width50">
<button :type="buttonSet.cancelType||'default'" @tap="hide()" :style="classObj.btnSize + (buttonSet.cancelStyle||'')">{{buttonSet.cancelName||'取消'}}</button>
</view>
<view class="flex_row_c_c width50">
<button :type="buttonSet.confirmType||'primary'" @tap="confirm()" :style="classObj.btnSize + (buttonSet.confirmStyle||'')">{{buttonSet.confirmName||'确定'}}</button>
</view>
</view>
</view>
</view>
</template>
<script>
import _app from './app.js';
var provinceData = {};
var cityData = {};
var areaData = {};
var streetData = {};
const Sys = uni.getSystemInfoSync();
const wH = Sys.screenHeight;
const wW = Sys.screenWidth;
export default {
name: 'QS-picker',
props: {
pickerId: {
type: String,
default: '未定义Id'
},
/* show: { //控制是否弹出
type: Boolean,
default: false
}, */
type: { //类型
type: String,
default: 'date'
},
height: { //picker高度
type: Number,
default: 0
},
lineHeight: {
type: Number,
default: .09
},
indicator_style: { //picker单行样式
type: String,
default: ''
},
fontscale: { //picker内文字大小
type: Number,
default: .02
},
width: { //picker宽度
type: Number,
default: .8
},
buttonSet: { //按钮设置
type: Object,
default () {
return {};
}
},
dataSet: { //各类型携带的数据
type: Object,
default () {
return {};
}
},
showReset: { //每次显示是否重置value
type: Boolean,
default: false
},
title: { //title标题
type: String,
default: ''
},
mode: {
type: String,
default: 'bottom'
},
zIndex: {
type: [Number, String],
default: 9999
},
bgColor_title: {
type: String,
default: '#F8F8F8'
},
autoHide: {
type: Boolean,
default: true
},
titleColor: {
type: String,
default: '#999'
},
contentColor: {
type: String,
default: 'black'
}
},
data() {
return {
showPicker: false,
setObj: {},
//date
years: [],
days: 0,
value: [],
//city、provincialStreet
provinceDataList: [],
cityDataList: [],
areaDataList: [],
//provincialStreet
streetDataList: [],
defaultValue: [],
wH,
classObj: {
btnSize: 'font-size: ' + (wH * (this.fontscale + .005)) + 'px;',
}
};
},
computed: {
heightSize() {
if(this.mode==='middle') {
return wH*(this.height||.3) + 'px';
}else{
return wH*(this.height||.45) + 'px';
}
},
titleSize() {
return (wH * (this.fontscale + .002)) + 'px';
},
contentSize() {
return (wH * this.fontscale) + 'px';
}
},
watch: {
dataSet() {
this.init();
},
showPicker(n, o) {
if (n && this.showReset) {
let defaultValue = this.defaultValue;
switch (this.type) {
case 'city':
this.cityDataList = cityData[defaultValue[0]];
this.areaDataList = areaData[defaultValue[0]][defaultValue[1]];
break;
case 'provincialStreet':
this.cityDataList = cityData[defaultValue[0]];
this.areaDataList = areaData[defaultValue[0]][defaultValue[1]];
this.streetDataList = streetData[defaultValue[0]][defaultValue[1]][defaultValue[2]];
break;
case 'date':
let data = _app.countDays(this.years[defaultValue[0]], defaultValue);
this.days = data.days;
this.value = data.val;
break;
default:
break;
}
this.value = [...defaultValue];
}
}
},
created() {
this.init();
},
methods: {
init() {
let value = [];
let setObj = {};
//date
let years = [];
let days = 0;
// city、provincialStreet
let provinceDataList;
let cityDataList;
let areaDataList;
//provincialStreet
let streetDataList;
switch (this.type) {
case 'date': //date
setObj = _app.creatDateObj(this.dataSet);
console.log('setObj: ' + JSON.stringify(setObj));
let defaultDate = setObj.defaultValue;
years = _app.countYears(setObj.startYear || (new Date().getFullYear() - 5), setObj.endYear || (new Date().getFullYear() +
5));
let endYear = years[years.length - 1];
let defaultYear = defaultDate.getFullYear(),
defaultMonth = defaultDate.getMonth(),
defaultDay = defaultDate.getDate(),
defaultHour = defaultDate.getHours(),
defaultMinute = defaultDate.getMinutes(),
defaultSecond = defaultDate.getSeconds();
let compareY = defaultYear > endYear;
let year = compareY ? endYear : defaultYear;
let month = compareY ? 11 : defaultMonth;
defaultDate[1] = month;
days = _app.countDays(year, defaultDate).days;
let dm = setObj.dateMode;
if (dm >= 1) {
if (compareY)
value.push(years.length - 1);
else
for (let i = 0; i < years.length; i++) {
if (year == years[i]) {
value.push(i);
}
}
}
if (dm >= 2) value.push(compareY ? 11 : month);
if (dm >= 3) value.push(compareY ? days : defaultDay - 1);
if (dm >= 4) value.push(defaultHour);
if (dm >= 5) value.push(defaultMinute);
if (dm >= 6) value.push(defaultSecond);
//date
this.years = years;
this.days = days;
this.setObj = setObj;
break;
case 'city':
value = this.dataSet.defaultValue || [0, 0, 0];
provinceData = require('./city-data/province.js').default;
cityData = require('./city-data/city.js').default;
areaData = require('./city-data/area.js').default;
provinceDataList = provinceData;
cityDataList = cityData[value[0]];
areaDataList = areaData[value[0]][value[1]];
//city、provincialStreet
this.provinceDataList = provinceDataList;
this.cityDataList = cityDataList;
this.areaDataList = areaDataList;
break;
case 'provincialStreet':
value = this.dataSet.defaultValue || [0, 0, 0, 0];
provinceData = require('./city-data/province.js').default;
cityData = require('./city-data/city.js').default;
areaData = require('./city-data/area.js').default;
streetData = require('./city-data/streets.js').default;
provinceDataList = provinceData;
cityDataList = cityData[value[0]];
areaDataList = areaData[value[0]][value[1]];
streetDataList = streetData[value[0]][value[1]][value[2]];
//provincialStreet
this.provinceDataList = provinceDataList;
this.cityDataList = cityDataList;
this.areaDataList = areaDataList;
this.streetDataList = streetDataList;
break;
case 'custom':
setObj = _app.creatCustomObj(this.dataSet);
if (setObj.defaultValue) {
value = setObj.defaultValue;
} else {
if (setObj.linkage) {
for (let i = 0; i < setObj.linkageNum; i++) {
value.push(0);
}
} else {
setObj.itemArray.forEach(item => {
value.push(0);
});
}
}
this.setObj = setObj;
break;
case 'custom2':
setObj = _app.creatCustom2Obj(this.dataSet);
if (setObj.defaultValue) {
value = setObj.defaultValue;
} else {
if (setObj.linkage) {
for (let i = 0; i < setObj.linkageNum; i++) {
value.push(0);
}
} else {
setObj.itemArray.forEach(item => {
value.push(0);
});
}
}
this.setObj = setObj;
break;
default:
break;
}
let defaultValue = [...value];
this.value = value;
this.defaultValue = defaultValue;
},
bindChange({
detail: {
value
}
}) {
// console.log(JSON.stringify(e))
let changevalue;
switch (this.type) {
case 'city':
changevalue = value;
if (this.value[0] !== changevalue[0]) {
// 第一级发生滚动
this.cityDataList = cityData[changevalue[0]];
this.areaDataList = areaData[changevalue[0]][0];
changevalue[1] = 0;
changevalue[2] = 0;
} else if (this.value[1] !== changevalue[1]) {
// 第二级滚动
this.areaDataList = areaData[changevalue[0]][changevalue[1]];
changevalue[2] = 0;
}
this.value = changevalue;
break;
case 'provincialStreet':
changevalue = value;
if (this.value[0] !== changevalue[0]) {
// 第一级发生滚动
this.cityDataList = cityData[changevalue[0]];
this.areaDataList = areaData[changevalue[0]][0];
this.streetDataList = streetData[changevalue[0]] && streetData[changevalue[0]][0] && streetData[changevalue[0]][
0
][0] ? streetData[changevalue[0]][0][0] : [];
changevalue[1] = 0;
changevalue[2] = 0;
changevalue[3] = 0;
} else if (this.value[1] !== changevalue[1]) {
// 第二级滚动
this.areaDataList = areaData[changevalue[0]][changevalue[1]];
this.streetDataList = streetData[changevalue[0]] && streetData[changevalue[0]][changevalue[1]] && streetData[
changevalue[0]][changevalue[1]][0] ? streetData[changevalue[0]][changevalue[1]][0] : [];
changevalue[2] = 0;
changevalue[3] = 0;
} else if (this.value[2] !== changevalue[2]) {
this.streetDataList = streetData[changevalue[0]] && streetData[changevalue[0]][changevalue[1]] && streetData[
changevalue[0]][changevalue[1]][changevalue[2]] ? streetData[changevalue[0]][changevalue[1]][changevalue[2]] :
[];
changevalue[3] = 0;
}
this.value = changevalue;
break;
case 'date':
let data = _app.countDays(this.years[value[0]], value);
this.days = data.days;
this.value = data.val;
break;
default:
this.value = value;
break;
}
},
confirm() {
let type = this.type;
let value = this.value;
let obj = {
type,
value,
pickerId: this.pickerId
}
let setObj = this.setObj;
let data;
switch (type) {
case 'date':
data = '';
let dateFormatArray = setObj.dateFormatArray;
console.log('dateFormatArray' + JSON.stringify(dateFormatArray));
for (let i = 1; i <= this.setObj.dateMode; i++) {
if (i <= 6) {
let j = i - 1;
let f = i - 2;
switch (i) {
case 1:
data += this.years[value[j]];
break;
case 2:
data += dateFormatArray[f] + (value[j] + 1);
break;
case 3:
data += dateFormatArray[f] + (value[j] + 1);
break;
default:
data += dateFormatArray[f] + value[j];
break;
}
}
}
break;
case 'city':
data = {
label: this._getLabel(),
value: this.value,
cityCode: this._getCityCode()
};
break;
case 'provincialStreet':
data = {
label: this._getprovincialStreetLabel(),
value: this.value,
cityCode: this._getCityCode()
};
break;
case 'custom':
let custom_datas = setObj.itemArray;
data = {};
let custom_val = this.value;
let custom_steps = setObj.steps;
if (setObj.linkage) {
if (setObj.linkageNum === 2) { //二级联动
data.steps1 = custom_datas[custom_val[0]];
data.steps2 = custom_datas[custom_val[0]][custom_steps.step_2_item][custom_val[1]];
} else if (setObj.linkageNum === 3) { //三级联动
data.steps1 = custom_datas[custom_val[0]];
if (!data.steps1)
_app.showToast('第一列中不存在第' + custom_val[0] + '项');
data.steps2 = data.steps1[custom_steps.step_2_item][custom_val[1]];
if (!data.steps2)
_app.showToast('第二列中不存在第' + custom_val[1] + '项');
data.steps3 = data.steps2[custom_steps.step_3_item][custom_val[2]];
if (!data.steps3)
_app.showToast('第三列中不存在第' + custom_val[2] + '项');
} else {
_app.showToast('不在指定范围中');
}
} else { //无联动
data = [];
for (let i = 0; i < custom_datas.length; i++) {
let d = custom_datas[i];
data.push(d[custom_val[i]]);
}
}
break;
case 'custom2':
let custom2_datas = setObj.linkage ? setObj.itemObject : setObj.itemArray;
let custom2_val = this.value;
if (setObj.linkage) {
data = {}
if (setObj.linkageNum === 2) { //二级联动
data.steps1 = custom2_datas.step_1[custom2_val[0]];
data.steps2 = custom2_datas.step_2[custom2_val[0]][custom2_val[1]];
} else if (setObj.linkageNum === 3) { //三级联动
data.steps1 = custom2_datas.step_1[custom2_val[0]];
if (!data.steps1)
_app.showToast('第一列中不存在第' + custom2_val[0] + '项');
data.steps2 = custom2_datas.step_2[custom2_val[0]][custom2_val[1]];
if (!data.steps2)
_app.showToast('第二列中不存在第' + custom2_val[1] + '项');
data.steps3 = custom2_datas.step_3[custom2_val[0]][custom2_val[1]][custom2_val[2]];
if (!data.steps3)
_app.showToast('第三列中不存在第' + custom2_val[2] + '项');
} else {
_app.showToast('不在指定范围中');
}
} else { //无联动
data = [];
for (let i = 0; i < custom2_datas.length; i++) {
let d = custom2_datas[i];
data.push(d[custom2_val[i]]);
}
}
break;
default:
break;
}
obj.data = data;
this.$emit('confirm', obj);
console.log(this.autoHide)
if(this.autoHide)
this.hide();
},
_getprovincialStreetLabel() {
let pcikerLabel =
this.provinceDataList[this.value[0]].label +
'-' +
this.cityDataList[this.value[1]].label +
'-' +
this.areaDataList[this.value[2]].label +
(this.streetDataList[this.value[3]] ? '-' + this.streetDataList[this.value[3]] : '');
return pcikerLabel;
},
_getLabel() {
let pcikerLabel =
this.provinceDataList[this.value[0]].label +
'-' +
this.cityDataList[this.value[1]].label +
'-' +
this.areaDataList[this.value[2]].label;
return pcikerLabel;
},
_getCityCode() {
return this.areaDataList[this.value[2]].value;
},
show() {
this.showPicker = true;
this.$emit('showQSPicker', {
pickerId: this.pickerId,
type: this.type
});
},
hide() {
this.showPicker = false;
this.$emit('hideQSPicker', {
pickerId: this.pickerId,
type: this.type
});
},
voidFc() {}
}
}
</script>
<style scoped>
/* middle */
.middle{
position: fixed;
left: 50%;
top: 50%;
opacity: 0;
pointer-events: none;
perspective: 2500upx;
transition: all .3s ease-in-out;
}
.middle.show{
transition-delay: .3s;
transform: translate(-50%, -50%);
pointer-events: auto;
opacity: 1;
}
.middle.hide{
transform: translate(-50%, -50%);
opacity: 0;
pointer-events: none;
}
.middle_view{
background-color: #FFF;
border-radius: 15upx;
overflow: hidden;
width: 80vw;
}
/* bottom */
.bottom{
position: fixed;
left: 0;
bottom: 0;
pointer-events: none;
perspective: 2500upx;
transition: all .3s ease-in-out;
transform: translateY(100%);
}
.bottom.show{
transform: translateY(0);
pointer-events: auto;
}
.bottom.hide{
transform: translateY(100%);
pointer-events: none;
}
.bottom_view{
width: 100vw;
background-color: white;
}
/* top */
.top{
position: fixed;
left: 0;
top: 0;
pointer-events: none;
perspective: 2500upx;
transition: all .3s ease-in-out;
transform: translateY(-100%);
}
.top.show{
transform: translateY(0);
pointer-events: auto;
}
.top.hide{
transform: translateY(-100%);
pointer-events: none;
}
.top_view{
width: 100vw;
background-color: white;
}
/* mask */
.mask{
position: fixed;
top: 0;
left: 0;
height: 100vh;
width: 100vw;
opacity: 0;
background-color: rgba(0,0,0,.6);
transition: all .3s ease-in-out;
pointer-events: none;
}
.mask.show{
opacity: 1;
pointer-events: auto;
}
.mask.hide{
opacity: 0;
transition: all .3s ease-in-out .3s;
pointer-events: none;
}
.flex_column_c_c {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.text_align_center {
text-align: center;
}
/* flex */
.flex_1 {
flex: 1;
}
.flex_column {
display: flex;
flex-direction: column;
}
.flex_row_e_none {
display: flex;
flex-direction: row;
justify-content: flex-end;
}
.flex_column_c_c {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.flex_row {
display: flex;
flex-direction: row;
}
.flex_row_none_c {
display: flex;
flex-direction: row;
align-items: center;
}
.flex_row_e_c {
display: flex;
flex-direction: row;
justify-content: flex-end;
align-items: center;
}
.flex_row_c_c {
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
}
.flex_row_between_c {
display: flex;
flex-direction: row;
justify-content: space-between;
align-items: center;
}
/* width height */
.width50 {
width: 50%;
}
.width100 {
width: 100%;
}
.width250rpx{
width: 250rpx;
}
.height100 {
height: 100%;
}
/* padding */
.padding20rpx{
padding: 20rpx;
}
view, block, botton, text, picker, picker-view picker-view-column {
box-sizing: border-box;
}
.backgroundColor_white{
background-color: white;
}
</style>