使用unocss进行css原子化开发

主要利用unocss的preset,制定自定义rule,配合正则表达式实现简单类名

1 设置flex属性

import type {
    Preset } from 'unocss

const directionAbbr = {
   
  col: 'column',
  colr: 'column-reverse',
  row: 'row',
  rowr: 'row-reverse',
}
//主轴方向
const justifyAbbr = {
   
  center: 'center',
  start: 'flex-start',
  end: 'flex-end',
  between: 'space-between',
  around: 'space-around',
  evenly: 'space-evenly',
}

//交叉轴方向
const alignAbbr = {
   
  center: 'center',
  start: 'flex-start',
  end: 'flex-end',
  baseline: 'baseline'
}

export function presetFlex( config?: {
     prefix?:string } ):Preset {
   
	const _config = {
    prefix: config?.prefix || 'sm' }
	const direction = Reflect.ownKeys(directionAbbr).join('|')
  	const justify = Reflect.ownKeys(justifyAbbr).join('|')
  	const align = Reflect.ownKeys(alignAbbr).join('|')
	
	const reg1 = new RegExp(
		`^${
     _config.prefix}-flex-(${
     direction})$`	
	)
	const reg2 = new RegExp(
		`^${
     _config.prefix}-flex-(${
     direction})-(${
     justify})-(${
     align
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值