2021-10-10

本文通过分析Bootstrap的源码,详细解释了Less预处理器中的~运算符如何用于字符串拼接,特别是在创建响应式栅格系统的应用。通过递归函数`.col()`,展示了如何构建1到12列的栅格布局,动态生成不同屏幕尺寸下的类名。这种方法允许灵活地调整栅格系统的列数,为前端开发者提供了便利。
摘要由CSDN通过智能技术生成

less中 ~ 表示 字符串拼接 例如(bootstrap的源码分析)

.make-grid-columns() {
	// 传入index=1;因为最下方 .col(1),所以传入的参数就是1
	.col(@index) { // initial
		// 在less中 ~ 表示字符串拼接 则
		// item = .col-xs-1, .col-sm-1, .col-md-1, .col-lg-1
    	@item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
    	//此时index+1   则 index=2
    	.col((@index + 1), @item);
  	}
 	//默认 grid-columns = 12  此时index = 2 和item = .col-xs-1, .col-sm-1, .col-md-1, .col-lg-1
	.col(@index, @list) when (@index =< @grid-columns) { // general; "=<" isn't a typo
		// .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2
    	@item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
    	//.col(3,'.col-xs-1, .col-sm-1, .col-md-1, .col-lg-1 , .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2')
    	//只要index<=12,那么就执行这个函数,最终就得到1-12列的栅格系统,更改 @grid-columns ,就可以更改栅格的总列数
    	.col((@index + 1), ~"@{list}, @{item}");
  	}
	.col(@index, @list) when (@index > @grid-columns) { // terminal
    	@{list} {
      	position: relative;
      	// Prevent columns from collapsing when empty
      	min-height: 1px;
      	// Inner gutter via padding
      	padding-left:  ceil((@grid-gutter-width / 2));
      	padding-right: floor((@grid-gutter-width / 2));
    	}
	.col(1);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值