您的位置:

CSS布局:完全掌握position属性

CSS布局:完全掌握position属性

更新:

一、position属性介绍

/**
 * 静态定位,元素默认属性,不受top,left,bottom,right影响
 */
position: static;

/**
 * 相对定位,相对于其正常位置定位,不影响其他元素位置
 */
position: relative;

/**
 * 绝对定位,相对于最近的非static定位的父元素定位
 */
position: absolute;

/**
 * 固定定位,相对于浏览器窗口定位
 */
position: fixed;

/**
 * 粘性定位,元素在滚动时定位,到达指定位置时变为固定定位
 */
position: sticky;

position属性是CSS中非常重要的布局属性,可以用来实现多种复杂的效果,如悬浮导航、弹性盒子、响应式布局等。理解并掌握不同类型的定位相对关系是熟练使用position属性的关键。

二、相对定位的应用

.relative-container {
  position: relative;
}

.relative-item {
  position: relative;
  top: 20px;
  left: 20px;
}

相对定位不会影响其他元素的位置,仅相对于元素的正常位置进行偏移。可以用来实现元素的微调和叠加效果。

三、绝对定位的应用

.absolute-container {
  position: relative;
}

.absolute-item {
  position: absolute;
  top: 20px;
  left: 20px;
}

绝对定位可以让元素脱离文档流,相对于距离最近的非static定位的父元素进行定位。常用于实现多列布局、轮播图等复杂布局效果。

四、固定定位的应用

.fixed-item {
  position: fixed;
  top: 20px;
  left: 20px;
}

固定定位让元素相对于浏览器窗口进行定位,不会随着页面的滚动而改变位置。常用于实现悬浮导航栏或返回顶部效果。

五、粘性定位的应用

.sticky-item {
  position: sticky;
  top: 20px;
}

粘性定位可以让元素在滚动时按指定位置定位,到达指定位置后则变为固定定位,不会影响其他元素位置。常用于实现顶部导航或滚动时的固定搜索框效果。

六、综合应用:响应式布局

.container {
  position: relative;
}

.item {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 768px) {
  .item {
    position: static;
    transform: none;
  }
}

通过相对定位和绝对定位实现响应式布局,当屏幕宽度小于768px时,取消绝对定位,通过静态定位实现自适应布局。

七、总结

掌握好position属性的使用可以让我们在前端开发中更灵活地实现各种复杂的布局效果,但需要注意避免使用绝对定位过度导致页面不可维护。在实际使用中,需结合实际场景合理运用,力求达到更好的视觉和用户体验效果。

CSS布局:完全掌握position属性

一、position属性介绍 /** * 静态定位,元素默认属性,不受top,left,bottom,right影响 */ position: static; /** * 相对定位,相对于其正常位置定

2023-12-08
探究CSS Object Position属性

2023-05-12
CSS 属性 - Position

2023-05-12
关于CSS中Position属性的应用

2023-05-12
CSS Flex 属性完全指南

2023-05-19
CSS Position属性:更好的定位元素

一、理解Position属性 CSS的Position属性,是一种控制元素位置的方式,在网页开发中非常常用,它指定元素在页面上的位置。它是一个非常重要的属性,掌握它的工作原理,可以更好的控制网页布局。

2023-12-08
如何使用CSS中的position属性实现布局?

2023-05-12
利用CSS中的position属性实现布局定位

2023-05-12
掌握CSS和HTML的定位属性,提升页面排版能力

2023-05-12
CSS Position属性及其用法详解

2023-05-12
优化你的网站页面布局:掌握border-spacing CS

当我们创建网站时,页面布局是非常重要的,因为它可以使整个网站看起来更吸引人,并且更易于阅读。然而,在进行布局时,有时需要使用表格来安排内容。了解如何使用CSS中的border-spacing属性可以帮

2023-12-08
CSS布局与HTML定位

2023-05-12
CSS position属性的应用场景

2023-05-12
CSS的定位position属性详解

2023-05-12
如何使用CSS中的top属性优化页面布局

2023-05-12
CSS position属性的相对/绝对定位

2023-05-12
CSS Position属性详解

2023-05-12
如何使用CSS的position属性实现元素的精准定位

2023-05-12
CSS定位属性实现网页布局

2023-05-12
when-present<#else>when-missing. (These only cover the last step of the expression; to cover the whole expression, use parenthesis: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)?? ---- ---- FTL stack trace ("~" means nesting-related): - Failed at: ${item.id} [in template "article/detail/index.ftl" at line 48, column 106] ---- Java stack trace (for programmers): ---- freemarker.core.InvalidReferenceException: [... Exception message was already printed; see it above ...] at freemarker.core.InvalidReferenceException.getInstance(InvalidReferenceException.java:134) at freemarker.core.EvalUtil.coerceModelToTextualCommon(EvalUtil.java:481) at freemarker.core.EvalUtil.coerceModelToStringOrMarkup(EvalUtil.java:401) at freemarker.core.EvalUtil.coerceModelToStringOrMarkup(EvalUtil.java:370) at freemarker.core.DollarVariable.calculateInterpolatedStringOrMarkup(DollarVariable.java:104) at freemarker.core.DollarVariable.accept(DollarVariable.java:63) at freemarker.core.Environment.visit(Environment.java:371) at freemarker.core.IteratorBlock$IterationContext.executedNestedContentForCollOrSeqListing(IteratorBlock.java:321) at freemarker.core.IteratorBlock$IterationContext.executeNestedContent(IteratorBlock.java:271) at freemarker.core.IteratorBlock$IterationContext.accept(IteratorBlock.java:244) at freemarker.core.Environment.visitIteratorBlock(Environment.java:645) at freemarker.core.IteratorBlock.acceptWithResult(IteratorBlock.java:108) at freemarker.core.IteratorBlock.accept(IteratorBlock.java:94) at freemarker.core.Environment.visit(Environment.java:335) at freemarker.core.Environment.visit(Environment.java:341) at freemarker.core.Environment.visit(Environment.java:341) at freemarker.core.Environment.process(Environment.java:314) at freemarker.template.Template.process(Template.java:383) at org.springframework.web.servlet.view.freemarker.FreeMarkerView.processTemplate(FreeMarkerView.java:332) at org.springframework.web.servlet.view.freemarker.FreeMarkerView.doRender(FreeMarkerView.java:266) at org.springframework.web.servlet.view.freemarker.FreeMarkerView.renderMergedTemplateModel(FreeMarkerView.java:220) at org.springframework.web.servlet.view.AbstractTemplateView.renderMergedOutputModel(AbstractTemplateView.java:181) at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:314) at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1431) at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1167) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1106) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:979) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1014) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:903) at jakarta.servlet.http.HttpServlet.service(HttpServlet.java:564) at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:885) at jakarta.servlet.http.HttpServlet.service(HttpServlet.java:658) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:205) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:149) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:174) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:149) at com.software.filter.HttpSpiderIdentifyFilter.doFilter(HttpSpiderIdentifyFilter.java:51) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:174) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:149) at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:116) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:174) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:149) at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:116) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:174) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:149) at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:116) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:174) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:149) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:167) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:90) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:482) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:115) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:93) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:340) at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:391) at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:63) at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:896) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1744) at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:52) at java.base/java.lang.VirtualThread.run(VirtualThread.java:309)