mirror of
				https://gitee.com/vant-contrib/vant.git
				synced 2025-10-26 17:22:11 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			99 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <div class="demo-home">
 | |
|     <h1
 | |
|       class="demo-home__title"
 | |
|       :class="{ 'demo-home__title--small': smallTitle }"
 | |
|     >
 | |
|       <img :src="config.logo" />
 | |
|       <span>{{ config.title }}</span>
 | |
|     </h1>
 | |
|     <h2 v-if="config.description" class="demo-home__desc">
 | |
|       {{ config.description }}
 | |
|     </h2>
 | |
|     <template v-for="(group, index) in config.nav">
 | |
|       <demo-home-nav :group="group" :lang="lang" :key="index" />
 | |
|     </template>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| import { config } from 'site-mobile-shared';
 | |
| import DemoHomeNav from './DemoHomeNav';
 | |
| 
 | |
| export default {
 | |
|   components: {
 | |
|     DemoHomeNav,
 | |
|   },
 | |
| 
 | |
|   computed: {
 | |
|     lang() {
 | |
|       const { lang } = this.$route.meta;
 | |
|       return lang;
 | |
|     },
 | |
| 
 | |
|     config() {
 | |
|       const { locales } = config.site;
 | |
| 
 | |
|       if (locales) {
 | |
|         return locales[this.lang];
 | |
|       }
 | |
| 
 | |
|       return config.site;
 | |
|     },
 | |
| 
 | |
|     smallTitle() {
 | |
|       return this.config.title.length >= 8;
 | |
|     },
 | |
|   },
 | |
| };
 | |
| </script>
 | |
| 
 | |
| <style lang="less">
 | |
| @import '../../common/style/var';
 | |
| 
 | |
| .demo-home {
 | |
|   box-sizing: border-box;
 | |
|   width: 100%;
 | |
|   min-height: 100vh;
 | |
|   padding: 46px 20px 20px;
 | |
|   background: #fff;
 | |
| 
 | |
|   &__title,
 | |
|   &__desc {
 | |
|     padding-left: 16px;
 | |
|     font-weight: normal;
 | |
|     line-height: 1;
 | |
|     user-select: none;
 | |
|   }
 | |
| 
 | |
|   &__title {
 | |
|     margin: 0 0 16px;
 | |
|     font-size: 32px;
 | |
| 
 | |
|     img,
 | |
|     span {
 | |
|       display: inline-block;
 | |
|       vertical-align: middle;
 | |
|     }
 | |
| 
 | |
|     img {
 | |
|       width: 32px;
 | |
|     }
 | |
| 
 | |
|     span {
 | |
|       margin-left: 16px;
 | |
|     }
 | |
| 
 | |
|     &--small {
 | |
|       font-size: 24px;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__desc {
 | |
|     margin: 0 0 40px;
 | |
|     color: rgba(69, 90, 100, 0.6);
 | |
|     font-size: 14px;
 | |
|   }
 | |
| }
 | |
| </style>
 |