143 lines
3.1 KiB
Vue
143 lines
3.1 KiB
Vue
|
|
<template>
|
|||
|
|
<view
|
|||
|
|
class="u-col"
|
|||
|
|
:class="['u-col-' + span, customClass]"
|
|||
|
|
:style="$u.toStyle(colStyle, customStyle)"
|
|||
|
|
@tap="onClick"
|
|||
|
|
>
|
|||
|
|
<slot></slot>
|
|||
|
|
</view>
|
|||
|
|
</template>
|
|||
|
|
|
|||
|
|
<script lang="ts">
|
|||
|
|
export default {
|
|||
|
|
name: 'u-col',
|
|||
|
|
options: {
|
|||
|
|
addGlobalClass: true,
|
|||
|
|
// #ifndef MP-TOUTIAO
|
|||
|
|
virtualHost: true,
|
|||
|
|
// #endif
|
|||
|
|
styleIsolation: 'shared'
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
</script>
|
|||
|
|
|
|||
|
|
<script setup lang="ts">
|
|||
|
|
import { computed } from 'vue';
|
|||
|
|
import { ColProps } from './types';
|
|||
|
|
import { $u, useChildren } from '../../';
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* col 布局单元格
|
|||
|
|
* @description 通过基础的 12 分栏,迅速简便地创建布局(搭配<u-row>使用)
|
|||
|
|
* @tutorial https://uviewpro.cn/zh/components/layout.html
|
|||
|
|
* @property {String|Number} span 栅格占据的列数,总12等分(默认0)
|
|||
|
|
* @property {String} text-align 文字水平对齐方式(默认left)
|
|||
|
|
* @property {String|Number} offset 分栏左边偏移,计算方式与span相同(默认0)
|
|||
|
|
* @example <u-col span="3"><view class="demo-layout bg-purple"></view></u-col>
|
|||
|
|
*/
|
|||
|
|
|
|||
|
|
const emit = defineEmits<{ (e: 'click'): void }>();
|
|||
|
|
|
|||
|
|
const props = defineProps(ColProps);
|
|||
|
|
|
|||
|
|
const { parentExposed } = useChildren('u-col', 'u-row');
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* gutter 给col添加间距,左右边距各占一半,从父组件u-row获取
|
|||
|
|
*/
|
|||
|
|
const gutter = computed(() => {
|
|||
|
|
return parentExposed?.value?.props?.gutter ?? 20;
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 计算水平排列方式
|
|||
|
|
* @returns {string}
|
|||
|
|
*/
|
|||
|
|
const uJustify = computed(() => {
|
|||
|
|
if (props.justify === 'end' || props.justify === 'start') return 'flex-' + props.justify;
|
|||
|
|
else if (props.justify === 'around' || props.justify === 'between') return 'space-' + props.justify;
|
|||
|
|
else return props.justify;
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 计算垂直对齐方式
|
|||
|
|
* @returns {string}
|
|||
|
|
*/
|
|||
|
|
const uAlignItem = computed(() => {
|
|||
|
|
if (props.align === 'top') return 'flex-start';
|
|||
|
|
if (props.align === 'bottom') return 'flex-end';
|
|||
|
|
else return props.align;
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 计算样式对象
|
|||
|
|
*/
|
|||
|
|
const colStyle = computed<any>(() => ({
|
|||
|
|
padding: `0 ${Number(gutter.value) / 2}px`,
|
|||
|
|
marginLeft: `${(100 / 12) * Number(props.offset)}%`,
|
|||
|
|
flex: `0 0 ${(100 / 12) * Number(props.span)}%`,
|
|||
|
|
alignItems: uAlignItem.value,
|
|||
|
|
justifyContent: uJustify.value,
|
|||
|
|
textAlign: props.textAlign
|
|||
|
|
}));
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 点击事件
|
|||
|
|
* @param e 事件对象
|
|||
|
|
*/
|
|||
|
|
function onClick(e: Event) {
|
|||
|
|
emit('click');
|
|||
|
|
}
|
|||
|
|
</script>
|
|||
|
|
|
|||
|
|
<style lang="scss">
|
|||
|
|
@import '../../libs/css/style.components.scss';
|
|||
|
|
|
|||
|
|
.u-col {
|
|||
|
|
/* #ifdef MP-WEIXIN || MP-QQ || MP-TOUTIAO */
|
|||
|
|
float: left;
|
|||
|
|
/* #endif */
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
.u-col-0 {
|
|||
|
|
width: 0;
|
|||
|
|
}
|
|||
|
|
.u-col-1 {
|
|||
|
|
width: calc(100% / 12);
|
|||
|
|
}
|
|||
|
|
.u-col-2 {
|
|||
|
|
width: calc(100% / 12 * 2);
|
|||
|
|
}
|
|||
|
|
.u-col-3 {
|
|||
|
|
width: calc(100% / 12 * 3);
|
|||
|
|
}
|
|||
|
|
.u-col-4 {
|
|||
|
|
width: calc(100% / 12 * 4);
|
|||
|
|
}
|
|||
|
|
.u-col-5 {
|
|||
|
|
width: calc(100% / 12 * 5);
|
|||
|
|
}
|
|||
|
|
.u-col-6 {
|
|||
|
|
width: calc(100% / 12 * 6);
|
|||
|
|
}
|
|||
|
|
.u-col-7 {
|
|||
|
|
width: calc(100% / 12 * 7);
|
|||
|
|
}
|
|||
|
|
.u-col-8 {
|
|||
|
|
width: calc(100% / 12 * 8);
|
|||
|
|
}
|
|||
|
|
.u-col-9 {
|
|||
|
|
width: calc(100% / 12 * 9);
|
|||
|
|
}
|
|||
|
|
.u-col-10 {
|
|||
|
|
width: calc(100% / 12 * 10);
|
|||
|
|
}
|
|||
|
|
.u-col-11 {
|
|||
|
|
width: calc(100% / 12 * 11);
|
|||
|
|
}
|
|||
|
|
.u-col-12 {
|
|||
|
|
width: calc(100% / 12 * 12);
|
|||
|
|
}
|
|||
|
|
</style>
|