CSS技巧让你的网站更上一层楼

2024-06-20 00:38

本文主要是介绍CSS技巧让你的网站更上一层楼,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 CSS是网站的外衣,所谓人靠衣装,佛靠金装,CSS决定了你给用户的第一感觉。虽然一直在做网站的架构和后端开发,但是还是需要多揣点CSS技巧,以防万一。

01.DIV水平居中

DIV 水平居中很简单,只需要设置DIV的宽带以及让左右margins设置成auto:

div#container {width: 960px; margin: 0 auto }

02.文字垂直居中

单行文字居中,只需要将行高和容器高度设置成一样即可。比如下面的HTML代码:

<div id="container">我是一行字</div>

然后通过下面的样式就可以居中:

div#container {height: 35px; line-height: 35px;}

如何你有很多行字,只要将行高设置成容器的高度的1/N就好。
03.DIV垂直居中

比如有以下两个div,如何让包在中间的div垂直居中,这里有一篇详细的介绍文章。

<div id="f">
 <div id="s">Some Things!</div>
</div>

首先,将外层容器的定位为relative。

div#f{ position:relative; height:500px; }

然后,将里面的容器定位设置成absolute,再将它的左上角沿y轴下移50%,最后将它margin-top上移本身高度的50%即可。

div#s { position: absolute; top: 50%; height: 250px; margin-top: -125px; }

使用同样的思路,也可以做出水平居中的效果。
04.自适应宽带的图片

可以通过以下样式实现只适用外层容器大小的图片:

img {max-width: 100%}
/* IE 6 hack */
<!--[if IE 6]>
img {width: 100%}
<![endif]-->

05.3D按钮

要想让按钮具有3D效果,可以将它的左上部边框设为浅色,右下部边框设为深色即可。

div#button {
   background: #888;
   border: 1px solid;
   border-color: #999 #777 #777 #999;
  }

06. CSS Font 缩写

body {
   font-family: Arial, Helvetica, sans-serif;
   font-size: 13px;
   font-weight: normal;
   font-variant: small-caps;
   font-style: italic;
   line-height: 150%;
}
/* 可以缩写成以下这种方式 */
body {
   font: font-style font-variant font-weight font-size/line-height font-family;
}

详细介绍参见:A Primer on the CSS Font Shorthand Property
06.可以在DIV上设置多个class

<div class="class-1 class-2 class-3">content</div>

  class-2 {color: blue} 
  class-3 {color: green} 
  class-1 {color: red}

08.圆角

CSS3中很容易实现圆角:

.element {border-radius: 5px}

但是在CSS3还没全民普及之前我在 Safari, Chrome, 之类 webkit 核心的浏览器中使用 -webkit-border-radius 以及在 Firefox 这些基于 Mozilla 的浏览器使用 -moz-border-radius 来实现圆角。

/* Safari, Chrome */
.element {
   border-radius: 5px
   -webkit-border-radius: 5px
   -moz-border-radius: 5px
}
/* Firefox */
.element {
   border-top-left-radius: 5px
   -webkit-border-top-left-radius: 5px
   -moz-border-radius-top-left
}

至于其他的浏览器可以用JQuery 插件来实现圆角。

$(".element").corner("5px");

09.link 状态的设置顺序

a:link 
a:visited 
a:hover 
a:active

简单记忆法:love hate (LVHA)
10.Clearing and Containing Floats

使用 float 和 clear 设置容器的排序,具体的还是看这篇文章吧。
11.条件注释

条件注释只适用于IE这个杯具的浏览器。

<!--[if IE]>
<link rel="stylesheet" type="text/css" href="ie-stylesheet.css" />
< ![endif]-->
<!--[if IE 6]> - targets IE6 only -->
<!--[if gt IE 6]> - targets IE7 and above -->
<!--[if lt IE 6]> - targets IE5.5 and below -->
<!--[if gte IE 6]> - targets IE6 and above -->
<!--[if lte IE 6]> - targets IE6 and below -->

12.HTML Hack for IE

IE这个杯具的浏览器可以通过以下方式进行 hack 。被hack的css只会运行在特定的浏览器上。

/* the following rules apply only to IE6 */
* html{
}
* html body{
}
* html .foo{
}

/* the following rules apply only to IE7 */
* html .foo{
}

13.CSS的优先级

基本规则是:行内样式 > id样式 > class样式 > 标签名样式。
14.IE中min-height修正

由于IE6不支持min-height,我们可以通过以下这些方式修正:

/* 方法一 */
.element {
 min-height: 500px;
 height: auto !important;
 height: 500px;
}

/* 方法二 */
.element {
 min-height: 500px
 _height: 500px /* _ 只有IE6才能读取 */
}

15.font-size 基准

/* 假设浏览器的默认的大小是 16px , 首先将其设置为10px (font-size:10/16) */
body {font-size:10/16;}
/* 然后就可以用em做统一字体单位了 2.4em = 24px */
h1 {font-size: 2.4 em}

16.100% Height

通过内部容器将页面撑开,在IE中的min-height可以通过上面hack解决:

  html, body {height: 100%}
  #content {min-height: 100%}

17. CSS Drop Caps

首字母样式定义:

p:first-letter {
  display: block;
  float: left;
  margin: 5px 5px 0 0;
  color: red
  font-size: 1.4em;
  background: #ddd;
  font-family: Helvetica;
}

18.取消link外面的框框

a {outline: none} or a {outline: 0}

19.Text-transform

p {text-transform: uppercase} /* 全部大写 */
p {text-transform: lowercase} /* 全部小写 */
p {text-transform: capitalize} /* 首字母大写 */

20.Font Variant

只对英文有效,将字体整成等高的大写字体。

p {font-variant: small-caps}

21.移除带有链接的图片的外框

  a image {border: none} or a image {border: 0}

22.重置浏览器的CSS

参考 YUI 和 Eric Meyer 吧。
23.设置背景图的 Padding

  /* background-position {top-value left-value} */
  {background-position: 5px 5px}

24.用图片列表标志

默认情况下,浏览器是用一个黑圆圈作为列表标志,我们用图片取代它:

  ul {list-style: none}
  ul li {
    background-image: url("dot.png");
    background-repeat: none;
    background-position: 0 0.5em;
  }

25.透明容器

如何将容器设置成透明:

.element {
  filter:alpha(opacity=50); /* for ie */
  -moz-opacity:0.5; /* for ff */
  -khtml-opacity: 0.5; /* for webkit as chrome */
  opacity: 0.5; /* for opera */
}

26.三角形

如何使用CSS生成一个三角形?简单方案:将它四个边框中的三个边框设为透明,只剩下一个,就可以生成三角形效果:

.element {
  border-color: transparent transparent green transparent;
  border-style: solid;
  border-width: 0px 300px 300px 300px;
  height: 0px;
  width: 0px;
}

27. 禁止自动换行

h1 { white-space:nowrap; }

28.用图片替换文字

为了杯具的SEO,我需要在标题栏里用图片展现,同时也要保证搜索引擎能读到标题。

h1 {
  text-indent:-9999px;
  background:url("h1-image.jpg") no-repeat;
  width:200px;
  height:50px;
}

29.突显焦点元素

input:focus { border: 2px solid green; }

30.!important

多条CSS语句冲突时,具有!important的语句将覆盖其他语句。由于IE不支持!important,所以也可以利用它区分不同的浏览器。

/* IE 显示蓝色标题,其他浏览器显示红色标题 */
h1 {
  color: red !important;
  color: blue;
}

31.CSS实现提示框

当鼠标移动到链接上方,会自动出现一个提示框:

  <a class="tooltip" href="#">Link<span>Tooltips</span></a>

  a.tooltip {position: relative}
  a.tooltip span {display:none; padding:5px; width:200px;}
  a:hover {background:#fff;} /*background-color is a must for IE6*/
  a.tooltip:hover span{display:inline; position:absolute;}

32.固定页头

当页面滚动的时候,页首固定在位置不变,适合导航条:

body{ margin:0;padding:100px 0 0 0;}
  div#header{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:<length>;
}

@media screen{
 body>div#header{position: fixed;}
}

* html body{overflow:hidden;}
* html div#content{height:100%;overflow:auto;}

这篇关于CSS技巧让你的网站更上一层楼的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1076609

相关文章

mtu设置多少网速最快? 路由器MTU设置最佳网速的技巧

《mtu设置多少网速最快?路由器MTU设置最佳网速的技巧》mtu设置多少网速最快?想要通过设置路由器mtu获得最佳网速,该怎么设置呢?下面我们就来看看路由器MTU设置最佳网速的技巧... 答:1500 MTU值指的是在网络传输中数据包的最大值,合理的设置MTU 值可以让网络更快!mtu设置可以优化不同的网

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行

Spring @RequestMapping 注解及使用技巧详解

《Spring@RequestMapping注解及使用技巧详解》@RequestMapping是SpringMVC中定义请求映射规则的核心注解,用于将HTTP请求映射到Controller处理方法... 目录一、核心作用二、关键参数说明三、快捷组合注解四、动态路径参数(@PathVariable)五、匹配请

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

Mac备忘录怎么导出/备份和云同步? Mac备忘录使用技巧

《Mac备忘录怎么导出/备份和云同步?Mac备忘录使用技巧》备忘录作为iOS里简单而又不可或缺的一个系统应用,上手容易,可以满足我们日常生活中各种记录的需求,今天我们就来看看Mac备忘录的导出、... 「备忘录」是 MAC 上的一款常用应用,它可以帮助我们捕捉灵感、记录待办事项或保存重要信息。为了便于在不同