文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Css3使用技巧有哪些

2024-04-02 19:55

关注

这篇文章主要为大家展示了“Css3使用技巧有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Css3使用技巧有哪些”这篇文章吧。

 

经典的css3实例本文会提到以下几个css3的属性:

 

border-radius、::after、attr和content、box-sizing、linear-gradient、radial-gradient、box-shadow

 

border-radius

 

相信这个属性,写过css的同学都知道,用来产生圆角,比如画一个圆形:

 

div {

    width:100px;

    height:100px;

    background:red;

    border-radius:100px; //border-radius:100%;

}

 

然后我们来看看它的语法:border-radius: [左上] [右上] [右下] [左下],于是我们来画一个半圆

 

div {

    width: 100px;

    height: 50px;

    background: red;

    border-radius: 50px 50px 0 0;

}

 

那如果要画一个椭圆该怎么办呢?你会发现上面的语法貌似做不到了,其实border-radius的值还有一种语法: x半径/y半径:

 

div {

    width: 100px;

    height: 50px;

    background: red;

    border-radius: 50px/25px;

}

 

如果我要画半个椭圆,又要咋办呢?

 

div {

    width: 100px;

    height: 50px;

    background: red;

    border-radius: 100% 0 0 100% /50%;

}

 

::after

 

这里拿个简单的例子来看,我们要画一个放大镜,如下图:

 

 

 

分析一下,这个放大镜可以由两个div组成,一个是黑色的圆环,一个是黑色把手(旋转45度)。所以我们就需要用两个div来实现吗?答案是NO,一个div也是可以的,我们可以借助::after来添加一个元素。同理如果需要三个div,我们还可以使用::before再添加一个元素。下面看一下代码:

 

div {

    width: 50px;

    height: 50px;

    border-radius: 50%;

    border: 5px solid #333;

    position: relative;

}

div::after {

    content: '';

    display: block;

    width: 8px;

    height: 60px;

    border-radius: 5px;

    background: #333;

    position: absolute;

    right: -22px;

    top: 38px;

    transform: rotate(-45deg);

}

 

attr和content

 

比如我们要实现一个悬浮提示的功能。传统方法,使用title属性就能实现,但是现在我们要更美观,可以使用css3提供的attr:能够在css中获取到元素的某个属性值,然后插入到伪元素的content中去。

 

假如我们的html代码如下:

 

<div data-title="hello, world">hello...</div>

 

我们来看看实现这个插件的css代码:

 

div {

    position: relative;

}

div:hover::after {

    content: attr(data-title); //取到data-title属性的值

    display: inline-block;

    padding: 10px 14px;

    border: 1px solid #ddd;

    border-radius: 5px;

    position: absolute;

    top: -50px;

    left: -30px;

}

 

当hover的时候,在元素尾部添加一个内容为data-title属性值的元素,所以就实现了hover显示的效果,如下图所示:

box-sizing

我们知道,在标准盒子模型中,元素的总宽=content + padding + border + margin。 css中的盒子模型大家可能都知道,但是这个盒子模型的属性可能没有那么多人知道,box-sizing属性就是用来重定义这个计算方式的,它有三个取值,分别是:content-box(默认)、border-box、padding-box

 

一般来说,假如我们需要有一个占宽200px、padding10px、border5px的div,经过计算,要这么定义样式。

 

div {

    width: 170px; //这里的宽度要使用200-10*2-5*2 = 170得到。

    height: 50px;

    padding: 10px;

    border: 5px solid red;

}

然后我们来使用一下box-sizing属性。

div {

    box-sizing: border-box;

    width: 200px; //这里的宽度就是元素所占总宽度,不需要计算

    height: 50px;

    padding: 10px;

    border: 5px solid red;

}

 

linear-gradient

做活动页面的时候我们经常会遇到这样的需求:

顶部的中间一张大banner图片,然后整个区域的背景色要根据图片背景色渐变。就可以使用这个属性了。

 

div {

    width: 200px;

    height: 50px;

    background: linear-gradient(to right, red, yellow, black, green);

}

是不是很有趣?其实,linear-gradient还有更多有趣的功能,你可以根据下面的动图去感受一下:

你以为这就完了?等等,还有更强大的呢!repeating-linear-gradient,来感受一下:

linear-gradient还有更加强大的功能,比如它可以给元素添加多个渐变,从而达到更NB的效果。

radial-gradient

上面的linear-gradient是线性渐变,这个属性是径向渐变。下面的代码实现了一个chrome的logo。

div.chrome {

    width: 180px;

    height: 180px;

    border-radius: 50%;

    box-shadow: 0 0 4px #999, 0 0 2px #ddd inset;

    background: radial-gradient(circle, #4FACF5 0, #2196F3 28%, transparent 28%),

    radial-gradient(circle, #fff 33%, transparent 33%),

    linear-gradient(-50deg, #FFEB3B 34%, transparent 34%),

    linear-gradient(60deg, #4CAF50 33%, transparent 33%),

    linear-gradient(180deg, #FF756B 0, #F44336 30%, transparent 30%),

    linear-gradient(-120deg, #FFEB3B 40%, transparent 40%),

    linear-gradient(-60deg, #FFEB3B 30%, transparent 30%),

    linear-gradient(0deg, #4CAF50 45%, transparent 45%),

    linear-gradient(60deg, #4CAF50 30%, transparent 30%),

    linear-gradient(120deg, #F44336 50%, transparent 50%),

    linear-gradient(180deg, #F44336 30%, transparent 30%);

}

 

实现原理就是使用了多个渐变色放在div上,友协被遮住,视觉上就产生了想要的效果,是不是很强大!看了下图你就知道其实就是在div上加了很多个渐变。

 

 

以上是“Css3使用技巧有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯