135 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <scroll-view class="wuc-tab" :class="tabClass" :style="tabStyle" scroll-with-animation scroll-x :scroll-left="scrollLeft">
 | |
|     <div v-if="!textFlex">
 | |
|       <div class="wuc-tab-item" :class="[index === tabCur ? selectClass + ' cur':'']" v-for="(item,index) in tabList" :key="index" :id="index" @tap="tabSelect(index,$event)">
 | |
|         <text :class="item.icon"></text>
 | |
|        <span>{{item.name}}</span>
 | |
|       </div>
 | |
|     </div>
 | |
| 
 | |
|     <div class="flex text-center" v-if="textFlex">
 | |
|       <div class="wuc-tab-item flex-sub" :class="index === tabCur ? selectClass + ' cur':''" v-for="(item,index) in tabList" :key="index" :id="index" @tap="tabSelect(index,$event)">
 | |
|         <text :class="item.icon"></text>
 | |
|         <span>{{item.name}}</span>
 | |
|       </div>
 | |
|     </div>
 | |
|   </scroll-view>
 | |
| </template>
 | |
| <script>
 | |
| export default {
 | |
|     name: 'wuc-tab',
 | |
|     data() {
 | |
|         return {};
 | |
|     },
 | |
|     props: {
 | |
|         tabList: {
 | |
|             type: Array,
 | |
|             default() {
 | |
|                 return [];
 | |
|             }
 | |
|         },
 | |
|         tabCur: {
 | |
|             type: Number,
 | |
|             default() {
 | |
|                 return 0;
 | |
|             }
 | |
|         },
 | |
|         tabClass: {
 | |
|             type: String,
 | |
|             default() {
 | |
|                 return '';
 | |
|             }
 | |
|         },
 | |
|         tabStyle: {
 | |
|             type: String,
 | |
|             default() {
 | |
|                 return '';
 | |
|             }
 | |
|         },
 | |
|         textFlex: {
 | |
|             type: Boolean,
 | |
|             default() {
 | |
|                 return false;
 | |
|             }
 | |
|         },
 | |
|         selectClass: {
 | |
|             type: String,
 | |
|             default() {
 | |
|                 return 'text-blue';
 | |
|             }
 | |
|         }
 | |
|     },
 | |
|     methods: {
 | |
|         tabSelect(index, e) {
 | |
|             if (this.currentTab === index) return false;
 | |
|             this.$emit('update:tabCur', index);
 | |
|             this.$emit('change', index);
 | |
|         }
 | |
|     },
 | |
|     computed: {
 | |
|         scrollLeft() {
 | |
|             return (this.tabCur - 1) * 60;
 | |
|         }
 | |
|     }
 | |
| };
 | |
| </script>
 | |
| <style>
 | |
| div,
 | |
| scroll-view,
 | |
| swiper {
 | |
| 	box-sizing: border-box;
 | |
| }
 | |
| .wuc-tab {
 | |
|     white-space: nowrap;
 | |
| }
 | |
| .wuc-tab-item {
 | |
|     height: 90upx;
 | |
|     display: inline-block;
 | |
|     line-height: 90upx;
 | |
|     margin: 0 10upx;
 | |
|     padding: 0 20upx;
 | |
| }
 | |
| 
 | |
| .wuc-tab-item.cur {
 | |
|     border-bottom: 4upx solid;
 | |
| }
 | |
| 
 | |
| .wuc-tab.fixed {
 | |
| 	position: fixed;
 | |
| 	width: 100%;
 | |
| 	top: 0;
 | |
| 	z-index: 1024;
 | |
| 	box-shadow: 0 1upx 6upx rgba(0, 0, 0, 0.1);
 | |
| }
 | |
| 
 | |
| .flex {
 | |
|     display: flex;
 | |
| }
 | |
| .text-center {
 | |
|     text-align: center;
 | |
| }
 | |
| .flex-sub {
 | |
|     flex: 1;
 | |
| }
 | |
| .text-blue{
 | |
| 	width: 50%;
 | |
|   color:#0081ff;
 | |
| }
 | |
| .text-white{
 | |
|   color:#ffffff;
 | |
| }
 | |
| .bg-white{
 | |
|     background-color: #ffffff;
 | |
| }
 | |
| .bg-blue{
 | |
|     background-color: #0081ff;
 | |
| }
 | |
| .text-orange{
 | |
|   color: #f37b1d
 | |
| }
 | |
| 
 | |
| .text-xl {
 | |
| 	font-size: 36upx;
 | |
| }
 | |
| </style>
 | 
