[新增] rate 组件
This commit is contained in:
		
							parent
							
								
									2fb6d43e39
								
							
						
					
					
						commit
						98626cdbd6
					
				
							
								
								
									
										19
									
								
								docs/docs/zh-CN/components/rate.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								docs/docs/zh-CN/components/rate.md
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,19 @@
 | 
			
		||||
::: demo
 | 
			
		||||
 | 
			
		||||
<template>
 | 
			
		||||
  <lay-rate></lay-rate>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import { ref } from 'vue'
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
  setup() {
 | 
			
		||||
 | 
			
		||||
    return {
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
:::
 | 
			
		||||
@ -84,6 +84,7 @@ export default {
 | 
			
		||||
      { id: 23, title: '头像',subTitle:"avatar" ,path: '/zh-CN/components/avatar' },
 | 
			
		||||
      { id: 24, title: '字段',subTitle:"field" ,path: '/zh-CN/components/field' },
 | 
			
		||||
      { id: 25, title: '空',subTitle:"empty" ,path: '/zh-CN/components/empty' },
 | 
			
		||||
      { id: 26, title: '评分',subTitle:"rate" ,path: '/zh-CN/components/rate' },
 | 
			
		||||
    ]
 | 
			
		||||
 | 
			
		||||
    const selected = ref(1)
 | 
			
		||||
 | 
			
		||||
@ -131,6 +131,11 @@ const zhCN = [
 | 
			
		||||
        path: '/zh-CN/components/empty',
 | 
			
		||||
        component: () => import('../../docs/zh-CN/components/empty.md'),
 | 
			
		||||
        meta: { title: '空' },
 | 
			
		||||
      },
 | 
			
		||||
      {
 | 
			
		||||
        path: '/zh-CN/components/rate',
 | 
			
		||||
        component: () => import('../../docs/zh-CN/components/rate.md'),
 | 
			
		||||
        meta: { title: '评分' },
 | 
			
		||||
      }
 | 
			
		||||
    ],
 | 
			
		||||
  },
 | 
			
		||||
 | 
			
		||||
@ -44,6 +44,7 @@ import LaySelectOption from './module/selectOption/index'
 | 
			
		||||
import LayScroll from './module/scroll/index'
 | 
			
		||||
import LayEmpty from './module/empty/index'
 | 
			
		||||
import LayFormItem from './module/formItem/index'
 | 
			
		||||
import LayRate from './module/rate/index'
 | 
			
		||||
 | 
			
		||||
const components: Record<string, IDefineComponent> = {
 | 
			
		||||
  LayRadio,
 | 
			
		||||
@ -86,7 +87,8 @@ const components: Record<string, IDefineComponent> = {
 | 
			
		||||
  LayScroll,
 | 
			
		||||
  LaySelectOption,
 | 
			
		||||
  LayEmpty,
 | 
			
		||||
  LayFormItem
 | 
			
		||||
  LayFormItem,
 | 
			
		||||
  LayRate
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
const install = (app: App, options?: InstallOptions): void => {
 | 
			
		||||
@ -143,6 +145,7 @@ export {
 | 
			
		||||
  LaySelectOption,
 | 
			
		||||
  LayEmpty,
 | 
			
		||||
  LayFormItem,
 | 
			
		||||
  LayRate,
 | 
			
		||||
  install,
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										9
									
								
								src/module/rate/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								src/module/rate/index.ts
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,9 @@
 | 
			
		||||
import type { App } from 'vue'
 | 
			
		||||
import Component from './index.vue'
 | 
			
		||||
import type { IDefineComponent } from '../type/index'
 | 
			
		||||
 | 
			
		||||
Component.install = (app: App) => {
 | 
			
		||||
  app.component(Component.name || 'LayRate', Component)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export default Component as IDefineComponent
 | 
			
		||||
							
								
								
									
										29
									
								
								src/module/rate/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								src/module/rate/index.vue
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,29 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <ul class="layui-rate">
 | 
			
		||||
    <li class="layui-inline">
 | 
			
		||||
      <i class="layui-icon layui-icon-rate-solid"></i>
 | 
			
		||||
    </li>
 | 
			
		||||
    <li class="layui-inline">
 | 
			
		||||
      <i class="layui-icon layui-icon-rate-solid"></i>
 | 
			
		||||
    </li>
 | 
			
		||||
    <li class="layui-inline"><i class="layui-icon layui-icon-rate"></i></li>
 | 
			
		||||
    <li class="layui-inline"><i class="layui-icon layui-icon-rate"></i></li>
 | 
			
		||||
    <li class="layui-inline"><i class="layui-icon layui-icon-rate"></i></li>
 | 
			
		||||
  </ul>
 | 
			
		||||
</template>
 | 
			
		||||
<script setup lang="ts">
 | 
			
		||||
import { defineProps, ref, withDefaults } from 'vue'
 | 
			
		||||
 | 
			
		||||
const rate = ref([])
 | 
			
		||||
 | 
			
		||||
const props = withDefaults(
 | 
			
		||||
  defineProps<{
 | 
			
		||||
    length?: number
 | 
			
		||||
    modelValue?: number
 | 
			
		||||
  }>(),
 | 
			
		||||
  {
 | 
			
		||||
    length: 5,
 | 
			
		||||
    modelValue: 0
 | 
			
		||||
  }
 | 
			
		||||
)
 | 
			
		||||
</script>
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user