CSS样式表的知识点

CSS通常称为CSS样式表或层叠样式表(级联样式表),主要用于设置HTML页面中的文本内容,为用户展现较具观赏的外表的。以下是小编来在优化网站时遇到的CSS一些小知识点。

边距清空

body,ul,ol,li,p,h1,h2,h3,h4,h5,h6,form,fieldse,table,td,img,div,dl,dt,dd,input{margin:0;padding:0;}
body{font-size:12px;}
img{border:none;}
li{list-style:none;}
input,select,textarea{outline:none;}
a{text-decoration:none;}

清除浮动

.clearfix:after{conter:"";display:block;clear:both;}
.clearfix{zoom:1;}

浏览器当做编辑器

浏览器地址栏输入代码,可直接将浏览当做编辑器

data:text/html,<html contenteditable>

鼠标隐藏

*{cursor:none!important;}

文字模糊效果

p{color:transparent;text-shadow:#111 0 0 5px;}

居中样式

垂直居中样式(translate css3需IE9)

.center-vertical{position:relative;top:50%;transform:translateY(-50%);}

水平居中样式(translate css3需IE9)

.center-horizontal{position:relative;left:50%;transform:translateX(-50%);}

多重边框

div{box-shadow:0 0 0 6px rgba(0,0,0,0.2),0 0 0 12px rgba(0,0,0,0.2),0 0 0 18px rgba(0,0,0,0.2),0 0 0 24px rgba(0,0,0,0.2);height:200px;margin:50px auto; width:400px;}

实时编辑css(IE6无效)

<!DOCTYPE html>
<html>
<body>
<style style="display:block" contentEditable>
body{color:blue}
</style>
</body>
</html>

文本框灰置

有时候,我们希望表单中的文本框是只读的,让用户不能修改其中的信息,如使

<input type="text" name="input1" value="鹿泽">

鹿泽的内容,”鹿泽”两个字不可以修改。实现的方式归纳一下,有如下几种。

方法1: onfocus=this.blur() 当鼠标放上就离开焦点

<input type="text" name="input1" value="鹿泽" onfocus=this.blur()>

方法2:readonly

<input type="text" name="input1" value="鹿泽" readonly>
<input type="text" name="input1" value="鹿泽" readonly="true">

方法3: disabled

<input type="text" name="input1" value="鹿泽" disabled="true">

css3 移动web样式媒体查询的变化

外联 :当屏幕等于小于480px调用new_file.css

内联:当屏幕大于480px调用使用本样式

<style>
@media screen and (max-width:480px){
body {
background: blue;
}
}
</style>

一定要注意and后面的空格

设置文本居中

text-align:center

属性规定元素中的文本的水平对齐方式,设置文本居中。

text-align的center应用在一个容器上,它只针对容器里面的文字以及容器里面的display为inline或者inline-block的容器,如果里面的容器display为block,则里面的容器的内容不会居中。

text-align具有向下传递性,会不断地向子元素传递。如果设置一个div,则其子div中的内容也会居中。

margin:0 auto

自动对齐,设置块元素或与之类似的元素居中。

用margin:0auto使元素产生位置变化,需要将其放在div中。需要使文本居中,只要将文本放在一个div中即可。不过,使用margin的时候需要注意的情况比较多,稍不注意的时候就容易导致margin失效。

float:left或margin:100px将magrin:0auto的效果覆盖。

使用margin需要指定DOCTYPE.DOCTYPE是指定浏览器用哪一种标准解析HTML代码,如果不指定,可能会不失效。此外,DOCTYPE前不能够有代码,否则也会导致margin;0auto失效。

CENTER

使布局居中。

<center>是将所有被包含的元素都居中显示,而text-align:center只是将元素下面的内联元素居中显示。但HTML5中不支持<center>,不建议使用该方法。

设置文本两端对齐

text-align:justify

text-align:justify属性是全兼容的,使用它实现两端对齐,需要注意在模块之间添加[空格/换行符/制表符]才能起作用,同样,实现文本对齐也是需要在字与字之间添加[空格/换行符/制表符]才能起作用。

IE中要实现块内单行两端对齐需要使用其私有属性text-align-last:justify配合,text-align-last要生效,必须先定义text-align为justify。

line-height:0解决标准浏览器容器底部多余的空白

.content{
text-align:justify;
text-align-last:justify;
line-height:0;
height:44px;
}

说明:模块使用[换行符]或[空格符]后,webkit浏览器中会引起最后一个模块有多余空白,使用font-size:0可清除该空格。

@media all and (-webkit-min-device-pixel-ratio:0){
.content{
font-size:0;
}
}

说明:

text-align-last:justify目前只有IE支持,标准浏览器需要使用.demo:after伪类模拟类似效果。

opera浏览器需要添加vertical-align:top才能完全解决底部多余的空白,且子类必须是inline-block元素。

.content:after{
display:inline-block;
overflow:hidden;
width:100%;
height:0;
content:'';
vertical-align:top;
}

设置文本溢出省略

CSS单行文本溢出省略问题

.overhidde{
width: 100px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}

这里的width属性是必须的,因为需要知道它的宽度是多少,才能判断溢出;

overflow:hidden;是为了隐藏溢出的文本;
white-space:nowrap;默认。空白会被浏览器忽略;
text-overflow:ellipsis;显示省略符号来代表被修剪的文本。

css多行文本溢出省略问题

.overhidden2{
height:53px;
width:100px;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
}

在这里height属性和overflow属性相结合是为了隐藏省略号一下的文本,大家可以试一下不加的效果,就一目了然了。

line-clamp属性是为了控制文本显示多少行。

关于display和box-orient,在这里简单说一下:

必须定义display属性才可以对box进行划分。
box-orient属性指定一个box子元素是否应按水平或垂直排列。

👋 感谢您的观看!

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享