Vue项目实现自适应的左右布局和上下布局

目录

问题描述

解决方案


问题描述

在Vue项目中,我们这些初学者可能会因为布局的问题而感到苦恼,下面我就来整理一下一种左右布局和上下布局的简单方式

解决方案: 

 左右布局:

我们布局一般使用的是div元素,不过div元素是块元素(会自动占满一整行),导致左右布局不好

实现,下面向大家展示一种flex布局来轻松解决这个问题,代码如下

.xpanel-wrapper-2 {
	height:100%;
	display: flex;
   .xpanel{

	padding:15px;
	height:100%;
	min-height:170px;
	background:url("../img/panel.png") center no-repeat;
	background-size:100% 100%;
	box-sizing:border-box;
	.xpanel_1 {	
            display: flex;
			flex-wrap: wrap;
			justify-content: space-between;
			padding:15px;
			height:40%;
			min-height:170px;
			
			background-size:100% 100%;
			box-sizing:border-box;
	   }
	   
   }
   .xpanel2 {
	flex-grow: 1;
	display: flex;
	padding:15px;
	height:100%;
	min-height:170px;
	background:url("../img/panel.png") center no-repeat;
	background-size:100% 100%;
	box-sizing:border-box;
   }
}

能看懂代码的小伙伴直接使用代码,稍微有些疑惑的小伙伴就来听我解释一下吧,我首先需要设置一个父盒子来包裹两个子盒子,在父盒子中设置flex布局,使用flex布局就能实现左右布局

display: flex;

然后在子盒子中设置

flex-grow: 1;

重点来说一下flow-grow:1的效果就是在未设置该属性的盒子里,盒子展示设置大小,然后设置该属性的盒子就能自动填充掉整个屏幕中余下的部分,从而实现自适应布局

上下布局:

这里面主要是通过行标签<a-row>和列标签<a-col>标签实现的

<a-row>
  <a-col :span="24">
  <a-col :span="12">
<div classs="xpanel_1">
   <newBar></newBar>
 </div>
 </a-col >
  <a-col :span="12">
<div class="xpanel_1">
  <radition></radition>
 </div>
   </a-col>
   </a-col>
</a-row>

能看懂的小伙伴直接拿走代码,稍有疑惑的伙伴请听我解释一下,我们这里是通过行标签<a-row>将需要上下布局的盒子包裹起来,然后通过列标签<a-col :span=""24>把列的空间分成24等份,在继续通过使用两个<a-col :span="12">的方式实现上下布局

感觉有帮助的小伙伴们,请点赞点赞点赞,收藏收藏收藏

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Vue项目实现自适应布局有多种方案。其中一种常用的方案是使用postcss-px-to-viewport插件。该插件可以将以像素为单位的样式属性转化为相应的视窗单位,从而实现自适应效果。 首先,你需要在项目开发环境中安装postcss-px-to-viewport插件。可以使用npm命令进行安装:npm i postcss-px-to-viewport -D。 然后,在项目根目录下创建一个.postcssrc.js文件,并添加以下配置: ```javascript module.exports = { plugins: { autoprefixer: {}, "postcss-px-to-viewport": { unitToConvert: "px", viewportWidth: 750, unitPrecision: 6, propList: ["*"], viewportUnit: "vw", fontViewportUnit: "vw", selectorBlackList: [], minPixelValue: 1, mediaQuery: true, exclude: [], landscape: false } } }; ``` 这个配置文件指定了要转换的单位为像素(px),UI设计稿的宽度为750,转换后的精度为6位小数,将转换所有css属性的单位为vw,字体也使用vw作为单位,不排除任何类名,设置最小像素值为1,在媒体查询中也进行转换,不进行直接替换属性值,不排除任何文件夹,不处理横屏情况。 安装完成并配置好后,插件将会在代码编译时自动将样式属性进行转换,实现自适应布局效果。 需要注意的是,如果你在vant项目中使用这个插件,可能会改变vant的样式。为了解决这个问题,有两种解决方式。一种是将设计稿大小改为375,因为vant是以375为参考的。另一种是在配置文件中添加以下内容: ```javascript module.exports = { plugins: { autoprefixer: {}, "postcss-px2rem-exclude": { remUnit: 75, exclude: /node_modules/i, selectorBlackList: ["van-"] } } }; ``` 以上配置中,remUnit设定为75,排除了node_modules文件夹下的样式文件,同时排除了以"van-"开头的类名,这样就可以避免vant框架相关组件或某些样式受到rem的影响。 使用postcss-px-to-viewport插件可以方便地实现Vue项目中的自适应布局。根据你的具体需求和项目情况,选择合适的配置方式来达到自适应效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue自适应布局3种方法](https://blog.csdn.net/qq_28512043/article/details/107949915)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue自适应布局](https://blog.csdn.net/weixin_46396187/article/details/108060145)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

起飞001

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值