前段基础之css样式

css介绍:

  css(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素。浏览器读到样式表是,它就会按照这个样式表来对文档进行格式化。

css的引入方式:

  1. 内联样式:<p style="color:red"> Hello world</p>
  2. 嵌入样式:在头文件中创建style在里边设置样式
  3. 由文件导入:<link href="mystyle.css" rel="stylesheet" type="text/css"/>

css选择器:

  基本选择器:
标签选择器 ----------------------------- p{color:"red"}
ID选择器   -----------------------------  #i1{background:"red"}
类别选择器  ----------------------------  .c1{font-size:14px}

注意:
样式类名不要用数字开头(有的浏览器不认)。
标签中的class属性如果有多个,要用空格分隔。

通用选择器  -----------------------------* {margin:0}
  层级选择器:
组合选择器:
    /*为所有的div和p标签设置边框属性*/
    div, p {border: 1px solid red;}

后代选择器:
    /*li内部的a标签设置字体颜色*/
    li a {color: green;}

儿子选择器:
    /*选择所有父级是 <div> 元素的 <p> 元素*/
    div>p {font-family: "Arial Black", arial-black, cursive;}

毗邻选择器
    /*选择所有紧接着<div>元素之后的<p>元素*/
    div+p {margin: 5px;}

弟弟选择器
    /*i1后面所有的兄弟p标签*/
    #i1~p { border: 2px solid royalblue;}
   属性选择器:
/*用于选取带有指定属性的元素。*/
p[title] {
  color: red;
}
/*用于选取带有指定属性和值的元素。*/
p[title="213"] {
  color: green;
}

/*上面常用↑*/

/*用于选取属性值包含指定值的每个元素*/
div[class~="c2"] {
  color: red;
}
/*用于选取带有以指定值开头的属性值的元素,该值必须是整个单词。*/
div[class|="c2"] {
  color: red;
}
/*匹配属性值以指定值开头的每个元素*/
div[class^="my"] {
  color: red;
}
/*匹配属性值以指定值结尾的每个元素*/
div[class$="s"] {
  color: red;
}
/*匹配属性值以指定值结尾的每个元素*/
div[class$="s"] {
  color: red;
}
/*匹配属性值包含指定值的每个元素*/
div[class*="sb"] {
  color: red;
}
   伪类选择器:
a:link {color: #FF0000} /* 未访问的链接 */

a:visited {color: #00FF00} /* 已访问的链接 */

a:hover {color: #FF00FF} /* 鼠标移动到链接上 */

a:active {color: #0000FF} /* 选定的链接 */ 

选择器的优先级:

css继承

   继承是css的一个主要特征,它依赖于祖先-后代的关系,继承是一种机制,它不仅可以应用于某个特定元素,还可以应用于它的后代。而css继承性权重非常低。

css优先级:

只要加了!importan它就是优先级最高的(不建议使用)

css属性操作:

css文本:

文本颜色:

颜色属性被用来设置文字的颜色。

颜色是通过CSS最经常的指定:

  • 十六进制值 - 如: FF0000
  • 一个RGB值 - 如: RGB(255,0,0)
  • 颜色的名称 - 如:  red

 边框:

  边框属性:

     1.border-width

     2.border-style

     3.border-color

#i1{
      border-width:2px;
      border-style:solid;
      border-color: red;    
}    

 通常使用简写方式:#i1{ border:2px solid red;}

         单独设置:

#i1 {
  border-top-style:dotted;
  border-right-style:solid;
  border-bottom-style:dotted;
  border-left-style:none;
}

display属性:

display="none"  ---------------------------------------------隐藏标签

注意与visibility:hidden的区别:

visibility:hidden可以隐藏某个元素,但隐藏的元素仍需占用与未隐藏之前一样的空间。也就是说,该元素虽然被隐藏了,但仍然会影响布局。

display:none可以隐藏某个元素,且隐藏的元素不会占用任何空间。也就是说,该元素不但被隐藏了,而且该元素原本占用的空间也会从页面布局中消失。

 display="block"  -------------------------------将内联标签设置为块级标签

display="inline"  --------------------------------块级标签设置为内联标签

display="inline-block"  ----------------------------------行内块元素

  margin外边距:   

.margin-test {
  margin-top:100px;
  margin-bottom:100px;
  margin-right:50px;
  margin-left:50px;
}
推荐使用简写:

.margin-test {
  margin: 5px 10px 15px 20px;
}
顺序:上右下左

常见居中:

.mycenter {
  margin: 0 auto;
}

  padding内填充:

.padding-test {
  padding-top: 5px;
  padding-right: 10px;
  padding-bottom: 15px;
  padding-left: 20px;
}
推荐使用简写:

.padding-test {
  padding: 5px 10px 15px 20px;
}
顺序:上右下左

补充:

提供一个,用于四边;
提供两个,第一个用于上-下,第二个用于左-右;
如果提供三个,第一个用于上,第二个用于左-右,第三个用于下;
提供四个参数值,将按上-右-下-左的顺序作用于四边;

  float属性:

    

三种取值
left:向左浮动 right:向右浮动 none:默认值,不浮动 清除浮动: clear语法: clear : none | left | right | both 取值: none : 默认值。允许两边都可以有浮动对象 left : 不允许左边有浮动对象 right : 不允许右边有浮动对象 both : 不允许有浮动对象 但是需要注意的是:clear属性只会对自身起作用,而不会影响其他元素。 父标签塌陷问题: .clearfix:after
{ content: ""; display: block; clear: both; }

overflow溢出属性:

visible -------------------------------默认值。内容不会被修剪,会呈现在元素框之外。
hidden ---------------------------------内容会被修剪,并且其余内容是不可见的。
scroll -----------------    内容会被修剪,但是浏览器会显示滚动条以便查看其余的内容。
auto ------------------------如果内容被修剪,则浏览器会显示滚动条以便查看其余的内容。
inherit ----------------------------------规定应该从父元素继承 overflow 属性的值。

定位(position):

  static:

  static 默认值,无定位,不能当作绝对定位的参照物,并且设置标签对象的left、top等值是不起作用的的。

        relative(相对定位):

  相对定位是相对于该元素在文档流中的原始位置,即以自己原始位置为参照物。有趣的是,即使设定了元素的相对定位以及偏移值,元素还占有着原来的位置,即占据文档流空间。对象遵循正常文档流,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义。

注意:position:relative的一个主要用法:方便绝对定位元素找到参照物。

  absolute(绝对定位):

  定义:设置为绝对定位的元素框从文档流完全删除,并相对于最近的已定位祖先元素定位,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块(即body元素)。元素原先在正常文档流中所占的空间会关闭,就好像该元素原来不存在一样。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。

重点:如果父级设置了position属性,例如position:relative;,那么子元素就会以父级的左上角为原始点进行定位。这样能很好的解决自适应网站的标签偏离问题,即父级为自适应的,那我子元素就设置position:absolute;父元素设置position:relative;,然后Top、Right、Bottom、Left用百分比宽度表示。

另外,对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。

  fixed:

  对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性 定义。 注意点: 一个元素若设置了 position:absolute | fixed; 则该元素就不能设置float。这 是一个常识性的知识点,因为这是两个不同的流,一个是浮动流,另一个是“定位流”。但是 relative 却可以。因为它原本所占的空间仍然占据文档流。

在理论上,被设置为fixed的元素会被定位于浏览器窗口的一个指定坐标,不论窗口是否滚动,它都会固定在这个位置。

示例代码:

                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                

原文地址:https://www.cnblogs.com/kxllong/p/8087380.html