百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

CSS3新特性——小案例

xsobi 2024-12-31 15:27 1 浏览

#大有学问#

本篇文章写两个案例。

一个是卡片布局案例,一个是logo平滑切换效果案例。

1.结构伪类选择器案例

布局思路

我将这个卡片分为四行模块。第一行是图片模块,第二行是文字部分,第三行进度条部分,第四行是按钮部分。

HTML代码结构

<div class="demo">
  <img src="../images/iphone.jpeg" alt="">
  <div>
    <p>Apple苹果iphone 6s Plus(A1699) 32G 金色 移动联通电信4G手机</p>
    <span>¥6088</span><span>¥6988</span>
  </div>
  <div>
    <p>已售<span>87%</span></p>
    <div>
      <div></div>
    </div>
    <p>剩余<span>29</span>件</p>
  </div>
  <input type="button" value="立即抢购">
</div>

CSS样式结构

我用了标签选择器和结构伪类选择器两种,没有使用类选择器。结构伪类选择器不太适用少量标签元素的。

* {
  margin: 0;
  padding: 0;
}
div:first-child {
  width: 234px;
  height: 400px;
  background-color: #fcfffc;
  border: 1px solid gray;
  padding: 0 4px;
  margin: 100px auto;
}
img {
  height: 206px;
  display: block;
  margin: 30px auto 25px;
}
p,
span {
  font-size: 12px;
  color: #797a7a;
}
div:first-child>div {
  padding: 0 6px;
}
div:first-child div:nth-of-type(1)  p {
  margin-bottom: 12px;
}
div:first-child div:nth-of-type(1) span:nth-child(2) {
  color: #c9493e;
  font-size: 20px;
  font-weight: 600;
  margin-right: 3px;
}
div:first-child div:nth-of-type(1) span:nth-child(3) {
  color: #a2a4a1;
  font-weight: 600;
  text-decoration: line-through;
}
div:first-child div:nth-of-type(2) {
  overflow: hidden;
  padding: 2px 6px;
}
div:first-child div:nth-of-type(2) p {
  float: left;
  font-size: 10px;
  line-height: 20px;
}
div:first-child div:nth-of-type(2)>div {
  width: 108px;
  height: 10px;
  border: 1px solid #d5685c;
  border-radius: 7px;
  float: left;
  margin: 5px;
}
div:first-child div:nth-of-type(2)>div>div {
  width: calc(80%);
  height: 10px;
  background-color: #ff5546;
  border-radius: 7px 0 0 7px;
  border: 0;
  margin: 0;
}
div:nth-of-type(2) span {
  color: red;
}
input {
  width: 234px;
  height: 40px;
  background-color: #bc2715;
  font-size: 16px;
  color: #ffdad7;
  border: 1px solid #d39f96;
}
input:hover {
  cursor:pointer;
}

2.logo过渡案例

布局思路

有一个大盒子.zH,里面包含一个有两个图片的小盒子.logo。当鼠标在大盒子.zH上悬停时切换logo图片。

给小盒子设置定位,通过修改left值,实现过渡效果。

HTML代码结构

<div class="zH">
  <div class="logo">
    <img src="../images/logo-mi2.png" alt="">
    <img src="../images/home.png" alt="">
  </div>
</div>

CSS样式结构

.zH {
  width: 60px;
  height: 60px;
  background-color: #ff6f00;
  border: 1px solid red;
  margin: 150px auto;
  position: relative;
  overflow: hidden;
}
.logo {
  width: 120px;
  height: 60px;
  background-color: #ff6f00;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  transition: all .5s ease-in-out;
}
.logo img {
  height: 60px;
  margin: 0;
  float: left;
}
.logo:hover {
  left: -60px;
}

代码运行结果演示,已经发了一个新的视频上传了,有兴趣的可以去看一下。

明天开始实战操作品优购项目。

相关推荐

C++中的多态(动态多态)究竟是如何实现

为了叙述简便,在本文中,将动态多态性一律简化为多态性。在前面的文章中,我们已经简要介绍了C++的多态性,也介绍了C++的虚函数表,下面,我们来看看C++是如何利用虚函数机制来实现多态性的。(题外话:实...

C++面向对象开发的四大特性:封装、抽象、继承、多态

1、封装封装,即隐藏对象的属性和实现细节,仅对外公开接口,控制程序对类属性的读取和修改。对于类的内部,成员函数可以自由修改成员变量,进行更精确的控制;对于类的外部,良好的封装能够减少耦合,同时隐藏实现...

C#知识|继承与多态

哈喽,你好啊,我是雷工01ProtectedProtected关键字表示这个属性只能给“子类”使用,即只能在子类内部使用,不能通过子类对象去使用;02父类定义父类...

朝文分享(54):深入C++(二十一)——多态

分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard新学苑。...

C++基础语法梳理:引用、封装、继承和多态

本期是C++基础语法分享的第六节,今天给大家来分享一下:(1)引用;...

继承和多态概念及语法

继承是面向对象编程的重要概念之一,它指的是一个类可以从另一个类中继承属性和方法。...

Java的多态如何实现的?

面向对象编程语言三大特征:继承、封装、多态。虽说是三大特征,但其实从多态的角度看,继承和封装都是为了实现多态而准备的,尤其是在一些大型优秀的框架上,多态的使用随处可见,所以说多态是一个十分重要的知识点...

C++中的多态性

封装、继承、多态是C++的三大基本特性。封装可以隐藏实现细节,使得代码模块化;继承可以扩展已存在的代码模块(类);封装和继承的目的都是为了"代码重用",多态则是为了实现另一个目的:接口...

讲解一下Java 中的多态

多态(Polymorphism)属于面向对象三大特征之一,它的前提是封装形成独立体,独立体之间存在继承关系,从而产生多态机制。多态是同一个行为具有多个不同表现形式或形态的能力。重载式多态,也叫编译时多...

java编程笔记,多态的好处和弊端

测试代码:1.创建Animal.java类作为父类2.创建Cat.java类作为Animal的子类3.创建一个Dog.java类作为Animal的子类4.创建Test.java测试类代码说明:多态的好...

C/C++编程笔记:C++多态性知识详解

多态性一词意味着具有多种形式。简而言之,我们可以将多态定义为消息以多种形式显示的能力。一个真实的多态示例:一个人同时可以具有不同的特征。像男人一样,是父亲,丈夫,雇员。因此,同一个人在不同情况下会表现...

用通俗易懂的多态世界观实例:理解python类的多态

什么是python类的多态python的多态,可以为不同的类实例,或者说不同的数据处理方式,提供统一的接口。用比喻的方式理解python类的多态...

多态——制作饮品

classAbstractDrinking{public://煮水virtualvoidBoil(){cout<<"煮农夫山泉"<&...

python之多态、继承、重写篇

#-*-coding:UTF-8-*-classAnimal:defrun(self):print("动物会跑。。")defsl...

Java面向对象——多态

前两天已经相继介绍了Java面向对象的三大特性之中的封装、继承,所以今天就介绍Java面向对象的三大特性的最后一项,多态~首先讲一下什么是多态,以及多态需要注意的细节什么是多态:一个对象具备多种...