当前位置:首页 > 技术分析 > 正文内容

两栏布局、左边定宽200px、右边自适应如何实现?

ruisui881个月前 (03-27)技术分析12

一、两栏布局(左定宽,右自动)
1. float + margin

即固定宽度元素设置float属性为left,自适应元素设置margin属性,margin-left应>=定宽元素宽度。

举例:

HTML代码:



我是左栏


我是右栏

CSS代码
html,body,div{
margin: 0;
padding: 0;
}
.wrap{
margin: 10px;
}
.wrap_left{
float: left;
width: 200px;
background-color: red;
}
.wrap_right{
margin-left: 220px;
background-color: green;
}

二、position + margin

即在父标签设置position属性为relative;子标签中定宽元素设置position属性为absolute;自适应元素设置margin属性,margin-left>=定宽元素宽度。

举例:

HTML代码



我是左栏


我是右栏



CSS代码

html,body,div{
margin: 0;
padding: 0;
}
.wrap{
margin: 10px;
position: relative;
}
.wrap_left{
position: absolute;
width: 200px;
background-color: red;
}
.wrap_right{
margin-left: 220px;
background-color: green;
}
3.float + 负margin

即给自适应宽度元素定义一个父标签,并设置float属性为left;width为100%;自适应宽度元素设置margin,margin-left应>=定宽元素宽度;

固定宽度元素设置margin-left属性为负值:-100%;

除此之外应注意HTML结构中应先写自适应元素,再写固定宽度元素。

举例:

HTML代码



我是右栏



我是左栏

html,body,div{
margin: 0;
padding: 0;
}
.wrap{
float: left;
width: 100%;
}
.wrap .wrap_right{
margin-left: 220px;
background-color: green;
}
.wrap_left{
float: left;
width: 200px;
margin-left: -100%;
background-color: red;
}
注:使用的float属性,必要时清除一下浮动。

二、三栏布局

掌握了上面的方法,我们会发现制作一个三栏布局也是非常容易的。

下面我们在上面栗子的基础上,看看实现一个两侧定宽,中间自适应的三栏布局如何实现

1. float + margin(两侧定宽,中间自适应)

HTML代码:

我是左栏

我是右栏

我是中间栏

html,body,div{

margin: 0;

padding: 0;

}

.wrap_left{

width: 200px;

float: left;

background-color: red;

clear: both;

}

.wrap_content{

margin-left: 220px;

margin-right: 220px;

background-color: yellow;

}

.wrap_right{

width: 200px;

float: right;

background-color: green;

}

2. position + margin(两侧定宽,中间自适应)

HTML代码:

我是左栏

我是右栏

我是中间栏

css代码

html,body,div{

margin: 0;

padding: 0;

}

.wrap_left{

width: 200px;

position: absolute;

background-color: red;

left: 0;

}

.wrap_content{

margin-left: 220px;

margin-right: 220px;

background-color: yellow;

}

.wrap_right{

width: 200px;

position: absolute;

right: 0;

background-color: green;

}

3.float + 负margin(两侧定宽,中间自适应)

HTML代码

我是中间栏

我是左栏

我是右栏

CSS代码

html,body,div{

margin: 0;

padding: 0;

}

.wrap{

float: left;;

width: 100%;

}

.wrap_left{

width: 200px;

float: left;

margin-left: -100%;

background-color: red;

}

.wrap_content{

margin-left: 220px;

margin-right: 220px;

background-color: yellow;

}

.wrap_right{

width: 200px;

float: left;

margin-left: -200px;

background-color: green;

}

文/丁向明

做一个有博客的web前端自媒体人,专注web前端开发,关注用户体验,加我qq/微信交流:6135833

http://dingxiangming.com

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/3066.html

标签: 宽度自适应
分享给朋友:

“两栏布局、左边定宽200px、右边自适应如何实现?” 的相关文章

一次Java内存占用高的排查案例,解释了我对内存问题的所有疑问

问题现象7月25号,我们一服务的内存占用较高,约13G,容器总内存16G,占用约85%,触发了内存报警(阈值85%),而我们是按容器内存60%(9.6G)的比例配置的JVM堆内存。看了下其它服务,同样的堆内存配置,它们内存占用约70%~79%,此服务比其它服务内存占用稍大。那为什么此服务内存占用稍大...

vue中router常见的三种传参方式

目录:我们在使用vue开发的过程中使用router跳转的时候肯定会遇到传参的情况;一般情况就三种传参是最常见的;那我们就来看看都有那几种传参方式吧!第一种:{ path: '/mall:id', name: 'Mall', component:...

深入理解vue-router原理

说到vue-router就表明他只适合于vue和vue是强绑定的关系;不适合其他框架;现在我们模仿实现一个VueRouter;1.要使页面刷新;借助vue本身的响应式原理;import Home from "./views/Home"; import About from "...

在vue项目中封装WebSockets请求

在Vue项目中封装WebSocket请求包括以下步骤:1. 安装WebSocket库:首先,导入WebSocket库,例如`vue-native-websocket`或`socket.io-client`。根据项目需求选择适当的库,并根据官方文档进行安装和配置。2. 创建WebSocket服务:在V...

尤雨溪:细聊 Vue 的现在与未来

大家好,我是 Echa。创作不易,喜欢的老铁们转发加个关注,点个赞,速速收藏,谢谢!另外咱们一起回顾一下Vue 优秀开源项目:12个又简单又实用的开源项目及组件推荐13个又热门又实用的Vue开源宝典库推荐7个Vue 3的高颜值UI组件库分享15个基于Vue3.0全家桶的优秀开源项目推荐10个基于Vu...

微信开发整合APP的“应用号” 以整合支付宝为谎言

据最新的消息称,自从前天微信公开课PRO版的各种谣言后,微信的相关人士就对于这个话题澄清后也发表了微信公众号的最新发展趋势。腾讯微信事业群总裁张小龙透露,微信公众平台的出发点并不是要做成一个只是传播内容的平台,而是一个提供服务的平台。“但是,目前的服务号依然没有达到要求。所以,微信正在开发一个新的形...