114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <div class="categories-wrapper card-box">
 | |
|     <router-link
 | |
|       to="/categories/"
 | |
|       class="title iconfont icon-wenjianjia"
 | |
|       title="全部分类"
 | |
|     >{{ length === 'all' ? '全部分类' : '文章分类' }}</router-link>
 | |
| 
 | |
|     <div class="categories">
 | |
|       <router-link
 | |
|         :to="`/categories/?category=${encodeURIComponent(item.key)}`"
 | |
|         v-for="(item, index) in categories"
 | |
|         :key="index"
 | |
|         :class="{active: item.key === category}"
 | |
|       >
 | |
|         {{item.key}}
 | |
|         <span>{{item.length}}</span>
 | |
|       </router-link>
 | |
|       <router-link
 | |
|         to="/categories/"
 | |
|         v-if="length !== 'all' && length < categoriesData.length"
 | |
|         class="more"
 | |
|       >更多 ...</router-link>
 | |
|     </div>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| export default {
 | |
|   props: {
 | |
|     category: {
 | |
|       type: String,
 | |
|       default: ''
 | |
|     },
 | |
|     categoriesData: {
 | |
|       type: Array,
 | |
|       default: []
 | |
|     },
 | |
|     length: {
 | |
|       type: [String, Number],
 | |
|       default: 'all'
 | |
|     }
 | |
|   },
 | |
|   computed: {
 | |
|     categories () {
 | |
|       if (this.length === 'all') {
 | |
|         return this.categoriesData
 | |
|       } else {
 | |
|         return this.categoriesData.slice(0, this.length)
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| </script>
 | |
| 
 | |
| <style lang='stylus'>
 | |
| .categories-wrapper
 | |
|   .title
 | |
|     color var(--textColor)
 | |
|     opacity 0.9
 | |
|     font-size 1.2rem
 | |
|     padding 0 .95rem
 | |
|     &::before
 | |
|       margin-right 0.3rem
 | |
|   .categories
 | |
|     margin-top 0.6rem
 | |
|     a
 | |
|       display block
 | |
|       padding 8px .95rem 7px .95rem
 | |
|       color var(--textColor)
 | |
|       opacity 0.8
 | |
|       font-size 0.95rem
 | |
|       line-height 0.95rem
 | |
|       position relative
 | |
|       transition all .2s
 | |
|       border-left 2px solid transparent
 | |
|       margin-top -1px
 | |
|       overflow hidden
 | |
|       white-space nowrap
 | |
|       text-overflow ellipsis
 | |
|       @media (max-width $MQMobile)
 | |
|         font-weight 400
 | |
|       &.more
 | |
|         // color $accentColor
 | |
|       &:not(.active):hover
 | |
|         color $accentColor
 | |
|         background #f8f8f8
 | |
|         border-color $accentColor
 | |
|         span
 | |
|           opacity 0.8
 | |
|       span
 | |
|         float right
 | |
|         background-color var(--textColor)
 | |
|         color var(--mainBg)
 | |
|         border-radius 8px
 | |
|         padding 0 0.13rem
 | |
|         min-width 1rem
 | |
|         height 1rem
 | |
|         line-height 1rem
 | |
|         font-size 0.6rem
 | |
|         text-align center
 | |
|         opacity 0.6
 | |
|         transition opacity 0.3s
 | |
|       &.active
 | |
|         background $accentColor
 | |
|         color var(--mainBg)
 | |
|         padding-left 0.8rem
 | |
|         border-radius 1px
 | |
|         border-color transparent
 | |
| .theme-mode-dark .categories-wrapper .categories a:not(.active):hover,
 | |
| .theme-mode-read .categories-wrapper .categories a:not(.active):hover
 | |
|   background var(--customBlockBg)
 | |
| </style>
 |