You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

163 lines
3.8 KiB
Vue

1 year ago
<!-- 需要配合tm-row使用也可以单独使用tm-col -->
<template >
<view class="tm-col" :class="[widths?'':'tm-col-'+grid, 'ma-' + margin,'mb-'+bma[1],'mx-'+bma[0]]"
:style="{
width:widths,
order: order,
verticalAlign: align,
}">
<view class="tm-col-body " @click="click" :style="{
textAlign:justify
}" :class="['pa-' + padding, aligns,` ${customClass} `,'round-'+round,color]"><slot></slot></view>
</view>
</template>
<script>
/**
* 栅格排版COL
* @description 请注意可以单独使用也可搭配row使用
* @property {String} color = [white|blue] 主题颜色名称更多请见文档
* @property {String} align = [top|bottom|middle] 默认top,内容纵向对齐方式
* @property {String} justify = [left|right|center] 内容横向对齐方式
* @property {String|Number} width = [100%] 宽度可以是数字其它百分比数字时单位为upx
* @property {String|Number} grid = [1|2|3|6|12] 列宽默认1 1-12自动计算百分比
* @property {String|Number} padding = [0] 内间距默认0
* @property {String|Number} margin = [0] 外间距默认0
* @property {String} custom-class = [] 自定义类
* @property {Number} round = [] 默认0圆角
* @property {Function} click = [] 点击事件
* @property {Number} maxCol = [] 默认12,布局的列表比如我想一行5个就可以用到此属性设置为10然后grid=2即可
* @property {String|Number} order = [0|1|2|3|4] 排列的顺序 默认0 可以是1-12的数字或者字符串
*/
export default {
props: {
// 自定义类。
customClass: {
type: String,
default: ''
},
// 圆角。
round: {
type: String|Number,
default: '0'
},
// 主题色。
color: {
type: String,
default: ''
},
// 自定义宽度。可以是数字单位如100vw,5%,auto,优先级高于grid
width: {
type: String | Number,
default: ''
},
// 列宽1-12自动计算百分比。
grid: {
type: String | Number,
default: 1
},
// 内间距。
padding: {
type: String | Number,
default: '0'
},
// 外间距。
margin: {
type: String | Number,
default: '0'
},
// 子项目横向对齐方式。 left|right|center
justify:{
type:String,
default:'center'
},
// 子项目纵向对齐方式。 top|bottom|middle
align:{
type:String,
default:'top'
},
// 排列的顺序。
order: {
type: String | Number,
default: '0'
},
maxCol:{
type:Number,
default:12
}
},
data() {
return {
widths:'',
bma:[0,0],
};
},
computed: {
maxCol_count:function() {
return this.maxCol||12;
},
aligns: function() {
if(this.justify == 'left') return 'flex-start';
if(this.justify == 'right') return 'flex-end';
if(this.justify == 'center') return 'flex-center';
},
},
async mounted() {
let pd = this.$tm.getParentAttr("tm-row",'gutter',this.$parent);
if(pd) this.bma = pd;
this.$nextTick(function(){
this.c_width();
})
},
methods: {
click(e){
this.$emit('click',e);
},
c_width() {
let t = this;
// 如果有自定义宽度优先使用自定的宽度否则使用grid的比例。
if (t.width.indexOf('%') > -1 || t.width.indexOf('vw') > -1 || t.width.indexOf('vh') > -1) {
t.widths = t.width;
return ;
}
if (t.width === 'auto') {
t.widths = "100%";
return;
}
if (!isNaN(parseFloat(t.width))) {
t.widths = uni.upx2px(parseInt(t.width)) + 'px';
return ;
}
t.widths = (parseInt(t.grid) / t.maxCol_count) * 100 + '%';
// console.log(t.maxCol_count);
}
},
};
</script>
<style lang="scss" scoped>
.tm-col{
height: inherit;
display: inline-block;
// #ifndef H5
height: 100%;
// #endif
.tm-col-body{
display: block;
}
}
</style>