• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > CSS解决链接锚点定位偏移的代码

CSS解决链接锚点定位偏移的代码

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含锚点定位,偏移等相关知识,佚名 希望在学习及工作中可以帮助到您
那假如我现在要求这个位置不是在顶端,而是离顶端有一定距离。
先看看我实现的方法例子:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>锚点位置偏移</title> <style> body,h2,p{ margin:0; padding:0; } h2,p{ width:500px; position:relative; } p{ height:400px; background:#CCC; z-index:2; } p.extra{ margin:0 0 500px; } h2{ margin:-200px 0 0; border-top:200px solid #000; z-index:1; background:#06F; } #anchor1{ margin:0; } span{ position:fixed !important; position:absolute; top:200px; left:510px; } #menu{ background:#CCC; position:fixed !important; position:absolute;left:510px; top:2px; } </style> </head> <body> <h2 id="anchor1">锚点111111111111111111111</h2> <p>有一定高度的层</p> <h2 id="anchor2">锚点222222222222222222222</h2> <p>有一定高度的层</p> <h2 id="anchor3">锚点333333333333333333333</h2> <p>有一定高度的层</p> <h2 id="anchor4">锚点444444444444444444444</h2> <p>有一定高度的层</p> <h2 id="anchor5">锚点555555555555555555555</h2> <p class="extra">底端需要一定高度才可以保证滚动条有足够高度让标题5到达指定位置</p> <div id="menu"><a href="#anchor1">去往锚点1</a> <a href="#anchor2">去往锚点2</a> <a href="#anchor3">去往锚点3</a> <a href="#anchor4">去往锚点4</a> <a href="#anchor5">去往锚点5</a></div> <span>&larr;目标在这里</span> </body> </html>
提示:您可以先修改部分代码再运行
这实际上是一种掩眼法,对齐的参考点还是在元素的顶端,只是我把元素的设置了特定的border-top(padding-top也可以,margin-top不可以),锚点就可以好像真的一样偏移到目标标题文字,但是这样会使下来元素之间产生一段距离,那么我们只要设置其margin-top为负值,而且刚好为padding-top的值即可。但是还会产生一个问题,margin-top为负数值时,会强行把元素的padding-top覆盖到上一元素上面(假如你没有设置背景色是很难看出来的),那怎么办呢?很自然我们就会想到z-index的方法,单纯设置z-index没有用,要先设置其positon为relative,这样就可以了。(注意:这里假如h2设置的padding-top值超过了p的高度[包括border和padding]值会引起层叠问题,解决方法是一样的。)

实例css代码:

有人可能会问为什么要这么麻烦?在这些元素的外面加一个父元素,然后把父元素移位不就成了么?这个确实是一个办法,但是假如你考虑到滚动条,你就会发现一个很难解决的问题,这里我就不介绍了。

您可能想查找下面的文章:

  • CSS解决链接锚点定位偏移的代码

相关文章

  • 2017-08-06CSS定义的PNG透明效果兼容各浏览器
  • 2017-08-06DIV实现简易漂浮层放置分页信息思路分享
  • 2017-08-06asp.net中获取客户端IP地址网卡信息等方法的代码
  • 2017-08-06table表格某一td内容太多导致样式混乱的解决方案
  • 2017-08-06将一个绝对定位的div水平垂直居中对齐
  • 2017-08-06css列表(新闻/下载)排行榜特效实现代码
  • 2017-08-06利用vertical-align:middle实现行内元素的水平垂直居中对齐
  • 2017-08-06基于html和CSS3制作酷炫的导航栏
  • 2017-08-06CSS选择器种类、优先级与匹配原理详解
  • 2017-08-06CSS权重关系及问题剖析

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • meta http-equiv="X-UA-Compatible" content="IE=7" 意思是将IE8用IE7进行渲染
    • css的语法介绍 css基础
    • CSS3的RGBA中关于整数和百分比值的转换
    • CSS3制作半透明边框(Facebox)类似渐变
    • DIV重叠 CSS让DIV层叠 两个DIV或多个DIV顺序重叠加
    • CSS设置DIV Herf底层图片和链接同时改变(兼容多浏览器)
    • favicon.ico在ie下面无法正常显示(尺寸32*32)
    • 用CSS让img input select button 图片,文本框,下拉菜单,按扭垂直居中的方法
    • 一个css transform效果 很有图片的感觉
    • 页面背景图片的拉伸实现代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有