zoukankan      html  css  js  c++  java
  • 前端第三天

    display:通过显示方式来分类:

    inline:同行显示,不支持宽高,宽高由内容决定

    block:异行显示,支持所有css样式,设置宽高

    inline-block:同行显示支持所有css样式

    盒模型:

    margin+border+padding+content,四个部分区域

    margin-top:|margin-left:完成自身布局

    margin-right|margin-bottom:影响兄弟布局

    当兄弟的上下布局重叠,取大值,父级与子级top重叠,取大值;解决办法

    给父级加padding-top或者父级加border-top

    显示宽高:border+padding+content

    自身布局:margin-top|margin-left

    兄弟布局:margin-bottom|margin-right

    父级水平居中:margin0 auto

    与inline相关的盒子 vertical-align

    屏幕水平居中:margin-left:calc((100% - 500px) / 2);

    屏幕水平居右:margin-left:auto;

    auto自适应父级可利用的剩余宽度 

    自适应水平居中:margin-left:auto;margin-right:auto;或者margin:0 auto;

    字体设置

    font-size:字体大小(参数也可以为inherit)继承父类

    font-weight:bold;字重 (100-900)|normal|lighter|bold

    font-family:"STSong","微软雅黑";第一个为默认属性,其他为当第一个属性不支持时的替代选项

    line-height:npx;行高

    text-align:center;水平居中方式

    color:red,字体颜色

    font:900 30px/120px "STSong";字重 大小/行高 字族

    em(自身->父->html) | rem(html)(rem中的r为root表示纸盒html字体大小关联)

    tent-indent:2em;(表示缩进)

    最小字体为12px

    字划线:

    underline(下划线):|line-through(中划线)|overline(上划线)

    text-decoration:overline;(上划线位置)

    reset操作

    太多系统预定义标签,有默认样式,但不满足实际开发需求,反倒影响布局,通常在开发前,将要用到的预定义标签的默认样式清除,该操作就称之为reset操作

    如:

    body,h1,h6,p{margin:0}

    ul{margin:0;padding:0;list-style:none;}

    a{text-decoration:none;color:black;}

    高级选择器:

    群组选择器:div,p,a{}(设置共同样式)

    同时控制多个,选择器之间使用逗号分开,每一个选择器位均可以替换为任意基础选择器或高级选择器

    后代:body div{}(中间使用空格分隔)(儿子可以使用>连接)通过关系层次控制一个目标选择器

    兄弟:.div1 ~ .div2{}(使用~连接)+表示相邻通过关系层次控制一个目标选择器

    位置:li:nth-child(n){}

    多类:.div.div1{}

    高级选择器优先级:

    优先级和个数(权重)相关

    基础选择器优先级占主导:id大于class大于标签

    选择器优先级相同时,和顺序有关,高级选择器类型不会影响优先级

    伪类选择器相当于class

    边界圆角

    左上为第一个角,顺时针赋值,不足找对角

    border-radius:30px,40px;当像素为长度一半时是一个圆

    a的四大伪类:

    :link 链接初始状态

    :hover 鼠标悬浮状态

    :visited 链接访问后的状态

    :active 鼠标按下时的状态

    cursor:为鼠标样式参数有pointer,等

    body {
    margin: 0;
    user-select: none;(禁止用户复制)
    }

    ul {
    margin: 0;
    padding: 0;
    list-style: none;表示列表去除选项
    }

    border:参数为1px solid black;((宽度)像素 实线 颜色)

    背景图片之精灵图:

    div{

    background:url("img/s.png") no-repeat 10px 20px;}

    参数分别为 图片地址 不平铺 x轴偏移,y轴偏移

    精灵图操作本质:控制背景图片的位置

    background-position-x:x;

    控制图片向右平移x像素

    background-position-y:y;

    控制图片向下平移y像素

    div:hover{background-position-y:-20px;}

    当鼠标移动到指定位置时,图片向上移动20像素

    background-image:url("sb.png");设置背景图片

    background-repeat:no-repeat;(禁止平铺) repeat-x|repeat-y|repeat分别为水平平铺,垂直平铺,全部平铺

    background-position:位置npx mpx;

    水平参数有left|center|right 垂直参数有:top|center|bottom

    .div:hover {
    transition: 2s; 表示延迟时间,默认为0,
    background-position-x: center; 表示将背景图片位置水平方向移动到中央
    }

    cursor: pointer;鼠标指针显示状态

  • 相关阅读:
    八数码难题 (codevs 1225)题解
    小木棍 (codevs 3498)题解
    sliding windows (poj 2823) 题解
    集合删数 (vijos 1545) 题解
    合并果子 (codevs 1063) 题解
    等价表达式 (codevs 1107)题解
    生理周期 (poj 1006) 题解
    区间 (vijos 1439) 题解
    区间覆盖问题 题解
    种树 (codevs 1653) 题解
  • 原文地址:https://www.cnblogs.com/suncunxu/p/10283924.html
Copyright © 2011-2022 走看看