CSS3学习

//首先CSS3的简介,过渡。
-webkit-transition: all 2s;/*低版本chrome和safie*/
            -moz-transition: all 2s;/*低版本火狐*/
            -o-transition: all 2s;/*低版本欧朋*/

            /*JS里面不支持 -- ,横杠去掉,字母变大写MoZtransition*/


//CSS3属性选择器
//CSS3新增自定义属性,aa是自定义属性。也可以替换成class

p[aa]//选中p元素并且类名为aa的元素

p[aa='k']//P元素类名为aa,类值为kk

p[a~='old']//指定类名,类值是一个词列表,且包含old

p[aa^='g']//类名开头为g

p[aa$='d']//类名结束为d

p[aa*='n']//属性只要包含n字符就会被选中

p[aa|='n']//类名是n||类名是 n-XX格式
//CSS3结构选择器
//even偶数,add奇数。也可以用2n来表示偶数。选择器是从0开始计数

p:nth-child(i)//找到p标签第i个子元素,并且元素类型为p

div>p:nth-of-type(odd)//计算方式为同类型

p:nth-last-child(1)//last

p:first-child{//=== nth-child(1)
 p:last-child

p:first-of-type//=== nth-child(1)
h1:last-of-type

p:empty//p元素不包括任何子节点,包括文本节点

h3:only-of-type//h3父元素仅有一个子节点,且类型为h3.

h4:only-child//h4的父元素仅为一个子节点,且类型为h4.
//下面是伪类和伪元素
//这段代码很奇怪,现在不理解

        div{
            width: 200px;
            height: 200px;
            background-color: black;
            color: whitesmoke;
            font-size: 66px;
            line-height: 200px;
            text-align: center;
            display: none;

        }
        div:target{/*target代表点击a的时候,上面产生的哈希值*//*表示突出显示活动的 HTML 锚*/
            display: block;
        }

<a href="#div1">div1</a>
<a href="#div2">div2</a>
<a href="#div3">div3</a>
<div id="div1">div1</div>
<div id="div2">div2</div>
<div id="div3">div3</div>
input:enabled//表示选中可输入状态的元素

input:disabled//表示选中不可输入状态的元素

input:checked//表示选中状态的元素

p~h1//选中p元素后面的h1[同级元素]

p:first-letter//选中p元素内第一个文字

P:first-line//选中p元素内第一行文字

p::selection/按下鼠标选择文字的时候会激活。使用的属性只有bg与color

p:before{//p文字最前面
    content:'秒味';
    background-color:red;
    border:1px solid #000;

}

p:after//p元素最后面

h1:not(.h2)//选中!(class==='h2')的h2元素
//还有rgba属性
direction:rtl; ||ltr;//设置文字排版
unicode-bidi://设置文字排列方向
box-shadow: 水平偏移 垂直偏移 模糊度 阴影扩展 阴影颜色 内外阴影;
/*box-shadow: 10px 10px 10px 10px skyblue inset;*/

text-shadow: 0px 2px 10px red,5px 5px 10px green;
            /*左右偏移量 上下偏移量 模糊距离 模糊颜色*/
-webkit-text-stroke:2px red ;//文字描边,只有webkit浏览器才支持
/*文本强制不换行,默认是换行的*/
            white-space: nowrap;
            /*超出边框隐藏*/
            overflow: hidden;
            /*文字溢出显示省略号*/
            /*这个是省略的意思*/
            text-overflow: ellipsis;

盒模型响应式布局

box-sizing:border-box;

background: -webkit-linear-gradient(right,red 0, blue 100%);//渐变属性

/*这个是倒影属性  目前只支持webkit内核的浏览器*/
            /*第一个参数有above|below|left|right 第二个参数是两者之间的距离*/
            -webkit-box-reflect: right 10px -webkit-linear-gradient(bottom,rgba(0,0,0,1) 0, rgba(0,0,0,0) 100%);

//-webkit-box-reflect:方向 倒影间隔 倒影样式设置
//结合背景图像生成可拖拽文档
resize:both;属性规定可由用户调整元素大小的属性
overflow: auto;//需要两条结合在一起使用

新的UI方案课件

/*圆角半径*/
            border-radius: 10px 20px;/*指的是对角*/
            /*
            如果是一个值,那么 top-left、top-right、bottom-right、bottom-left 四个值相等。

如果是两个值,那么 top-left和bottom-right相等,为第一个值,top-right和bottom-left值相等,为第二个值。

如果是三个值,那么第一个值是设置top-left,而第二个值是 top-right 和 bottom-left 并且他们会相等,第三个值是设置 bottom-right。

如果是四个值,那么第一个值是设置 top-left, 而第二个值是 top-right 第三个值 bottom-right 第四个值是设置 bottom-left
            */

/*x轴半径,y轴半径。比较常见的椭圆*/
        border-radius: 100px/150px;
            //边框背景
            width: 200px;
            height: 200px;
            border: 20px solid #000;
            /*图片地址,
             border-image-slice: 20 20 20 20; //指定边框图像上,右,下,左内测偏移量。作用就是把边框图像切成9个区域:4个角、4边区域和一个中间部位,前辈们都谦虚称作9宫格,但是我悄悄跟你说哦

            */

            /*对于这个元素来说,其实也是分为了九个格子。而图片也是分为了九个格子*/
            border-image: url("../border.png");
            border-image-slice: 27 27 27 27 ;
            border-image-width: 20px;
            /*border-image-repeat: repeat;*/

            /*stretch 拉伸
            repeat 重复
            round 平铺
            */

            /*
            三种包括
            border-image-source: ; //引入图片
            border-image-slice: ; // 切割图片
            border-image-width: ; //边框背景宽度
            border-image-repeat: repeat; //图片排列方式


            */


            /*
            border-image-slice: 27;指定了上,右,下,左图片内容的偏移量。(偏移的是图片)
            关于这个元素的详尽解释: 他的作用是将边框分割为九宫格的形式,而图片也是被分为了九宫格。然后就匹配啦
            */


/*多边框颜色只支持在火狐下面实现*/
            -moz-border-left-colors: red pink green;
            /*线性渐变*/
            background-image: -webkit-linear-gradient(left ,pink 0%,red 100%);
            // -webkit-linear-gradient(渐变方向[方向||deg],pink 0%,red 100%);
            background-image: -webkit-linear-gradient(left ,pink 0%,red 100%);
background-image:-webkit-linear-gradient(left,red 0%,red 30%,green 30%,green 70%,blue 70%);//设置无偏差的颜色
            background-image: -webkit-repeating-linear-gradient(left,red 0px,blue 30px) ;//表示颜色平铺渐变
颜色平铺渐变
//还有多重背景,加逗号就可以啦
            /*ellipse表示椭圆*/
            /*circle表示圆*/
background: -webkit-radial-gradient(/*50px*/ top,circle,red,black);//径向渐变
background: -webkit-radial-gradient(50px 100px,red,black);//径向渐变
//设置背景图的大小。cover:width&&height都铺满,contain:只满足一个
background-size: 100px 200px;//cover[覆盖],contain[包含]
//背景基点设置。
background-origin: content-box;//参数:padding-box||content-box||border-box;
//背景裁切
background-clip: border-box;//设置从哪个地方开始显示,区域的都变成了白色
其中,有一个非常好玩的属性
-webkit-background-clip:text;//文字后面显示background,其余是白色[webkit,firefox,opera都已支持]

//此外还有一个遮罩效果
-webkit-mask: url(../mask.png) no-repeat;//设置背景图片都取反 n== 透明||不透明。使用mast的图片===(!n);//主流浏览器已实现
遮罩效果

过渡和2D变换

transition:过渡属性 过渡时长 运动速度 延迟时间;
transition:width 2s, height 2s,background-color 5s;//经常与hover连用
**可以使用贝塞尔曲线**

//过渡没完成一条属性,就会触发 一次事件transition

    function addEnd(obj,fn){
        /*发生在过度完成之后*/
        obj.addEventListener('WebkitTransitionEnd',fn,false);/*在chrome下*/
        obj.addEventListener('transitionend',fn,false);/*在标准浏览器*/
    }
//2D变换
transform: rotateY(300deg);//rotateX||rotateY||rotateZ//旋转

transform: skew(30deg,90deg);//表示斜切 (X,Y)。父元素切过来,子元素还需要再切过去。

transform: scale(1.3,0.5);//X轴与Y轴缩放

transform: translate(100px,200px);//位移(X轴,Y轴,3D变换中还有Z轴)

transform-origin:0px 100px;//这个是变化基点。参数可以是方向和数值

-webkit-transform: matrix(1,0,0,1,100,200);//martix

3D变换笔记

-webkit-transform-style: preserve-3d;//建立3D空间
-webkit-perspective: 800px;//建立景深

perspective-origin: center center;//从哪个方向观看。参数是数值或者方向[X轴,Y轴]
/*运动总时间 延迟时间  关键帧的名字 运行状态 重复次数 */
            /**/
            animation: 2s 1s move ease-in infinite;

            animation-play-state: paused;//设置播放模式running

            animation-direction:alternate;/*alternate 倒序播放。[偶数次是倒回来]。normal是正常播放*/

          animation-fill-mode
        none: 不做任何改变
            forwards: 让元素结束状态保持动画最后一帧的样式
            backwards: 让元素等待状态的时候显示动画第一帧的样式
            both: 让元素等待状态显示动画第一帧的样式, 让元素结束状态保持动画最后一帧的样式

//动画执行结束会触发一个动画事件

function addEnd(obj,fn)
    {
        obj.addEventListener('webkitAnimationEnd',fn, false);
        obj.addEventListener('animationend',fn, false);
    }


a:link{*/
            /*color: green;*/
        /*}*/
        /*a:visited{*/
            /*color: green;*/
        /*}*/
        a:hover{
            color: orange;
        }
        a:active{
            color: pink;
        }


//江哥

/*a:link{*/
            /*color: green;*/
        /*}*/
        /*a:visited{*/
            /*color: green;*/
        /*}*/
        a:hover{
            color: orange;
        }
        a:active{
            color: pink;
        }

transition:过渡属性 过渡时长 运动速度 延迟时间;

transform:rotate(45deg);//代表旋转 translate(100px, 0px);//代表平移 scale(1.5,0.5)//代表缩放 (X,Y)


transform-origin: 200px 0px; //表示形变中心点

perspective: 500px;

box-shadow: 水平偏移 垂直偏移 模糊度 阴影扩展 阴影颜色 内外阴影;
/*box-shadow: 10px 10px 10px 10px skyblue inset;*/

animation
animation-fill-mode
        none: 不做任何改变
            forwards: 让元素结束状态保持动画最后一帧的样式
            backwards: 让元素等待状态的时候显示动画第一帧的样式
            both: 让元素等待状态显示动画第一帧的样式, 让元素结束状态保持动画最后一帧的样式

背景尺寸属性:background-size: 具体px 与% contain宽或者高填满内容  cover高和宽分别填满内容


background-origin: padding-box;border-box;content-box;
background-image: url("images/animal1.png"),url("images/animal2.png"),url("images/animal3.png");
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352