c7add6cf
“wangming”
初始版本开发完毕
|
1
|
<template>
|
25852764
unknown
s
|
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<u-popup mode="bottom" :border-radius="borderRadius" :popup="false" v-model="value" :maskCloseAble="maskCloseAble"
length="auto" :safeAreaInsetBottom="safeAreaInsetBottom" @close="popupClose" :z-index="uZIndex">
<view class="u-tips u-border-bottom" v-if="tips.text" :style="[tipsStyle]">
{{tips.text}}
</view>
<block v-for="(item, index) in list" :key="index">
<view
@touchmove.stop.prevent
@tap="itemClick(index)"
:style="[itemStyle(index)]"
class="u-action-sheet-item u-line-1"
:class="[index < list.length - 1 ? 'u-border-bottom' : '']"
:hover-stay-time="150"
|
c7add6cf
“wangming”
初始版本开发完毕
|
15
|
>
|
25852764
unknown
s
|
16
17
|
<text>{{item.text}}</text>
<text class="u-action-sheet-item__subtext u-line-1" v-if="item.subText">{{item.subText}}</text>
|
c7add6cf
“wangming”
初始版本开发完毕
|
18
|
</view>
|
25852764
unknown
s
|
19
20
|
</block>
<view class="u-gab" v-if="cancelBtn">
|
c7add6cf
“wangming”
初始版本开发完毕
|
21
|
</view>
|
25852764
unknown
s
|
22
23
|
<view @touchmove.stop.prevent class="u-actionsheet-cancel u-action-sheet-item" hover-class="u-hover-class"
:hover-stay-time="150" v-if="cancelBtn" @tap="close">{{cancelText}}</view>
|
c7add6cf
“wangming”
初始版本开发完毕
|
24
25
26
27
|
</u-popup>
</template>
<script>
|
c7add6cf
“wangming”
初始版本开发完毕
|
28
|
/**
|
25852764
unknown
s
|
29
|
* actionSheet 操作菜单
|
c7add6cf
“wangming”
初始版本开发完毕
|
30
31
|
* @description 本组件用于从底部弹出一个操作菜单,供用户选择并返回结果。本组件功能类似于uni的uni.showActionSheetAPI,配置更加灵活,所有平台都表现一致。
* @tutorial https://www.uviewui.com/components/actionSheet.html
|
25852764
unknown
s
|
32
33
34
35
36
37
38
39
40
41
42
43
|
* @property {Array<Object>} list 按钮的文字数组,见官方文档示例
* @property {Object} tips 顶部的提示文字,见官方文档示例
* @property {String} cancel-text 取消按钮的提示文字
* @property {Boolean} cancel-btn 是否显示底部的取消按钮(默认true)
* @property {Number String} border-radius 弹出部分顶部左右的圆角值,单位rpx(默认0)
* @property {Boolean} mask-close-able 点击遮罩是否可以关闭(默认true)
* @property {Boolean} safe-area-inset-bottom 是否开启底部安全区适配(默认false)
* @property {Number String} z-index z-index值(默认1075)
* @property {String} cancel-text 取消按钮的提示文字
* @event {Function} click 点击ActionSheet列表项时触发
* @event {Function} close 点击取消按钮时触发
* @example <u-action-sheet :list="list" @click="click" v-model="show"></u-action-sheet>
|
c7add6cf
“wangming”
初始版本开发完毕
|
44
45
46
|
*/
export default {
name: "u-action-sheet",
|
25852764
unknown
s
|
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
props: {
// 点击遮罩是否可以关闭actionsheet
maskCloseAble: {
type: Boolean,
default: true
},
// 按钮的文字数组,可以自定义颜色和字体大小,字体单位为rpx
list: {
type: Array,
default () {
// 如下
// return [{
// text: '确定',
// color: '',
// fontSize: ''
// }]
return [];
}
},
// 顶部的提示文字
tips: {
type: Object,
default () {
return {
text: '',
color: '',
fontSize: '26'
}
}
},
// 底部的取消按钮
cancelBtn: {
type: Boolean,
default: true
},
// 是否开启底部安全区适配,开启的话,会在iPhoneX机型底部添加一定的内边距
safeAreaInsetBottom: {
type: Boolean,
default: false
},
// 通过双向绑定控制组件的弹出与收起
value: {
type: Boolean,
default: false
},
// 弹出的顶部圆角值
borderRadius: {
type: [String, Number],
default: 0
},
// 弹出的z-index值
zIndex: {
type: [String, Number],
default: 0
},
// 取消按钮的文字提示
cancelText: {
type: String,
default: '取消'
|
c7add6cf
“wangming”
初始版本开发完毕
|
106
107
108
|
}
},
computed: {
|
25852764
unknown
s
|
109
110
111
112
113
114
115
|
// 顶部提示的样式
tipsStyle() {
let style = {};
if (this.tips.color) style.color = this.tips.color;
if (this.tips.fontSize) style.fontSize = this.tips.fontSize + 'rpx';
return style;
},
|
c7add6cf
“wangming”
初始版本开发完毕
|
116
117
118
119
|
// 操作项目的样式
itemStyle() {
return (index) => {
let style = {};
|
25852764
unknown
s
|
120
121
|
if (this.list[index].color) style.color = this.list[index].color;
if (this.list[index].fontSize) style.fontSize = this.list[index].fontSize + 'rpx';
|
c7add6cf
“wangming”
初始版本开发完毕
|
122
|
// 选项被禁用的样式
|
25852764
unknown
s
|
123
|
if (this.list[index].disabled) style.color = '#c0c4cc';
|
c7add6cf
“wangming”
初始版本开发完毕
|
124
125
126
|
return style;
}
},
|
25852764
unknown
s
|
127
128
129
130
|
uZIndex() {
// 如果用户有传递z-index值,优先使用
return this.zIndex ? this.zIndex : this.$u.zIndex.popup;
}
|
c7add6cf
“wangming”
初始版本开发完毕
|
131
132
|
},
methods: {
|
c7add6cf
“wangming”
初始版本开发完毕
|
133
|
// 点击取消按钮
|
25852764
unknown
s
|
134
135
136
137
138
|
close() {
// 发送input事件,并不会作用于父组件,而是要设置组件内部通过props传递的value参数
// 这是一个vue发送事件的特殊用法
this.popupClose();
this.$emit('close');
|
c7add6cf
“wangming”
初始版本开发完毕
|
139
|
},
|
25852764
unknown
s
|
140
141
142
|
// 弹窗关闭
popupClose() {
this.$emit('input', false);
|
c7add6cf
“wangming”
初始版本开发完毕
|
143
|
},
|
25852764
unknown
s
|
144
145
146
147
148
149
150
|
// 点击某一个item
itemClick(index) {
// disabled的项禁止点击
if(this.list[index].disabled) return;
this.$emit('click', index);
this.$emit('input', false);
}
|
c7add6cf
“wangming”
初始版本开发完毕
|
151
152
153
154
155
|
}
}
</script>
<style lang="scss" scoped>
|
25852764
unknown
s
|
156
|
@import "../../libs/css/style.components.scss";
|
c7add6cf
“wangming”
初始版本开发完毕
|
157
|
|
25852764
unknown
s
|
158
159
|
.u-tips {
font-size: 26rpx;
|
c7add6cf
“wangming”
初始版本开发完毕
|
160
|
text-align: center;
|
25852764
unknown
s
|
161
162
163
164
|
padding: 34rpx 0;
line-height: 1;
color: $u-tips-color;
}
|
c7add6cf
“wangming”
初始版本开发完毕
|
165
|
|
25852764
unknown
s
|
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
|
.u-action-sheet-item {
@include vue-flex;;
line-height: 1;
justify-content: center;
align-items: center;
font-size: 32rpx;
padding: 34rpx 0;
flex-direction: column;
}
.u-action-sheet-item__subtext {
font-size: 24rpx;
color: $u-tips-color;
margin-top: 20rpx;
}
|
c7add6cf
“wangming”
初始版本开发完毕
|
181
|
|
25852764
unknown
s
|
182
183
184
185
|
.u-gab {
height: 12rpx;
background-color: rgb(234, 234, 236);
}
|
c7add6cf
“wangming”
初始版本开发完毕
|
186
|
|
25852764
unknown
s
|
187
188
|
.u-actionsheet-cancel {
color: $u-main-color;
|
c7add6cf
“wangming”
初始版本开发完毕
|
189
190
|
}
</style>
|