2024-08-21



/* 设置父容器进行3D转换 */
.nav-container {
    perspective: 600px; /* 定义透视视图的范围,增强3D效果 */
    width: 100%;
    height: 100vh;
    transform-style: preserve-3d; /* 保持子元素的3D转换 */
}
 
/* 设置导航链接的基本样式 */
.nav {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
}
 
/* 设置导航链接的3D转换 */
.nav li {
    position: relative;
    transform-origin: center; /* 设置变形的原点,默认中心点 */
    transition: transform 0.5s ease; /* 设置过渡动画 */
}
 
/* 鼠标悬停时的3D旋转效果 */
.nav li:hover {
    transform: rotateX(90deg); /* 沿X轴旋转90度 */
}
 
/* 设置导航链接的具体样式 */
.nav a {
    display: block;
    padding: 10px;
    text-decoration: none;
    color: white;
    background-color: #333;
    margin: 5px;
    width: 100px;
    text-align: center;
}

这个示例展示了如何使用CSS3的3D转换来创建一个简单的3D导航栏。当鼠标悬停在导航链接上时,链接会沿X轴旋转90度。透视视图增加了3D效果,并且使用了transform-style: preserve-3d;来保持3D转换的子元素。

2024-08-21

CSS3背景渐变可以使用linear-gradientradial-gradient函数实现线性渐变或径向渐变效果。阴影可以使用box-shadow属性为盒模型添加阴影。

导航栏可以通过无序列表<ul>和列表项<li>来创建,然后通过CSS对其进行样式设计。

以下是实现方式的示例代码:




/* 导航栏样式 */
.navigation {
  list-style-type: none; /* 移除列表项前的默认符号 */
  padding: 0; /* 移除padding */
  margin: 0; /* 移除margin */
  background: linear-gradient(to right, #ff7e5f, #feb47b); /* 线性渐变背景 */
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.2); /* 盒模型阴影 */
}
 
.navigation li {
  float: left; /* 列表项浮动 */
  display: inline; /* 列表项内联显示 */
  margin-right: 20px; /* 列表项间距 */
}
 
.navigation li a {
  color: white; /* 文字颜色 */
  text-decoration: none; /* 去除下划线 */
  padding: 10px 20px; /* 文字内填充 */
  display: block; /* 转换为块级元素 */
}
 
.navigation li a:hover {
  background-color: #d8544e; /* 鼠标悬停背景色 */
}



<!-- 导航栏HTML -->
<ul class="navigation">
  <li><a href="#">首页</a></li>
  <li><a href="#">关于我们</a></li>
  <li><a href="#">产品服务</a></li>
  <li><a href="#">联系方式</a></li>
</ul>

这段代码展示了如何创建一个带有渐变背景、阴影以及鼠标悬停效果的简单导航栏。

2024-08-21

@font-face 是 CSS3 的一个特性,它允许开发者在网页中使用自定义的字体。要使用 @font-face,你需要指定字体的名称、来源和一些可选的参数。

以下是 @font-face 的基本用法:




@font-face {
  font-family: 'MyCustomFont';
  src: url('mycustomfont.woff') format('woff'),
       url('mycustomfont.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

在上面的例子中,font-family 指定了字体的名称,src 指定了字体文件的路径和格式。font-weightfont-style 分别指定了字体的粗细和样式。

在 HTML 中使用自定义字体:




body {
  font-family: 'MyCustomFont', sans-serif;
}

在上面的 HTML 中,我们将 body 的字体设置为 MyCustomFont,如果浏览器不支持这种字体,则会使用 sans-serif 这种默认字体。

2024-08-21



/* 定义3D舞台 */
.carousel-3d {
    width: 300px;
    height: 200px;
    perspective: 600px;
}
 
/* 定义每个3D盒子 */
.carousel-3d .box {
    width: 100%;
    height: 100%;
    position: absolute;
    transform-style: preserve-3d;
    transition: transform 1s;
}
 
/* 定义6个面 */
.carousel-3d .box .side {
    width: 100%;
    height: 100%;
    position: absolute;
    background: #ccc;
    border: 1px solid #000;
}
 
/* 动画:旋转3D盒子 */
@keyframes rotateBox {
    0% {
        transform: rotateY(0deg);
    }
    100% {
        transform: rotateY(360deg);
    }
}
 
/* 应用动画到盒子 */
.carousel-3d .box {
    animation: rotateBox 10s linear infinite;
}

这段代码定义了一个简单的3D旋转木马效果,通过@keyframes规则创建了一个名为rotateBox的动画,使得盒子绕Y轴连续旋转。每个盒子都是绝对定位的,并且通过transform-style: preserve-3d;保留3D效果。通过设置perspective属性给人一种深度感,同时transition属性用于定义盒子变化时的过渡效果。

2024-08-21

CSS3中的三大特性分别是继承性、层叠性和优先级。

  1. 继承性:

    指的是某些CSS属性会被应用到元素的所有子元素上,如字体的颜色、字体大小等。

    例如:

    
    
    
    div {
        color: red;
    }

    这段代码中,div的颜色被设置为红色,但这个颜色属性会自动应用到div的所有子元素上。

  2. 层叠性:

    指的是当多个选择器选中同一个元素,并且每个选择器都定义了相同的属性时,就会发生层叠。层叠性决定了在冲突的样式中哪个会被应用。

    例如:

    
    
    
    div {
        color: red;
    }
    div {
        color: blue;
    }

    在这个例子中,div的颜色会被应用为蓝色,因为后面的规则会覆盖前面的规则。

  3. 优先级:

    当多个选择器选中同一个元素,并且每个选择器都定义了相同的属性时,就需要确定哪个选择器的样式会被应用。优先级决定了在层叠中哪个选择器的样式会被应用。

    例如:

    
    
    
    div {
        color: red;
    }
    .highlight {
        color: blue;
    }
    <div class="highlight"></div>

    在这个例子中,div的颜色会被应用为红色,因为div选择器的优先级高于.highlight选择器。

优先级规则:

  • 内联样式(在HTML元素的style属性中)>
  • ID选择器 >
  • 类选择器、属性选择器、伪类 >
  • 元素选择器、伪元素 >
  • 通配选择器(*) >
  • 继承的样式。

注意:当两个选择器的优先级相同时,后定义的选择器会覆盖先定义的选择器。

2024-08-21

在Vue2项目中使用Three.js并在3D模型上方显示信息框,可以使用CSS3DSprite创建一个精灵模型来代表信息框。以下是一个简化的例子:

  1. 安装Three.js:



npm install three
  1. 在Vue组件中创建Three.js场景,并添加3D模型和CSS3DSprite信息框:



<template>
  <div ref="threeContainer"></div>
</template>
 
<script>
import * as THREE from 'three';
import { CSS3DRenderer, CSS3DSprite } from 'three/examples/jsm/renderers/CSS3DRenderer.js';
 
export default {
  name: 'ThreeModelWithLabel',
  mounted() {
    this.initThree();
    this.add3DModel();
    this.addLabelSprite();
    this.animate();
  },
  methods: {
    initThree() {
      const width = this.$refs.threeContainer.clientWidth;
      const height = this.$refs.threeContainer.clientHeight;
 
      this.scene = new THREE.Scene();
      this.camera = new THREE.PerspectiveCamera(75, width / height, 0.1, 1000);
      this.renderer = new THREE.WebGLRenderer();
      this.renderer.setSize(width, height);
      this.$refs.threeContainer.appendChild(this.renderer.domElement);
 
      this.cssRenderer = new CSS3DRenderer();
      this.cssRenderer.setSize(width, height);
      this.cssRenderer.domElement.style.position = 'absolute';
      this.cssRenderer.domElement.style.top = 0;
      this.$refs.threeContainer.appendChild(this.cssRenderer.domElement);
 
      this.camera.position.z = 5;
    },
    add3DModel() {
      const geometry = new THREE.BoxGeometry();
      const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });
      this.cube = new THREE.Mesh(geometry, material);
      this.scene.add(this.cube);
    },
    addLabelSprite() {
      const sprite = new CSS3DSprite(document.createElement('div'));
      sprite.scale.set(0.2, 0.2, 0.2);
      sprite.position.set(0, 1, 0); // 在模型上方1单位处创建精灵模型
      sprite.material.transparent = true;
      this.scene.add(sprite);
      this.labelSprite = sprite;
    },
    animate() {
      requestAnimationFrame(this.animate);
      this.renderer.render(this.scene, this.camera);
      this.cssRenderer.render(this.scene, this.camera);
 
      // 示例:旋转模型和标签位置
      this.cube.rotation.x += 0.01;
      this.cube.rotation.y += 0.01;
      this.labelSprite.rotation.x += 0.01;
      this.labelSprite.rotat
2024-08-20



<!DOCTYPE html>
<html>
<head>
<style>
.slider {
  overflow: hidden;
  white-space: nowrap;
  background: #f0f0f0;
}
 
.slide {
  display: inline-block;
  width: 100%;
  transition: transform 0.4s ease-in-out;
}
 
.slide img {
  width: 100%;
  display: block;
}
 
.slide p {
  position: absolute;
  bottom: 10px;
  left: 10px;
  background: rgba(0, 0, 0, 0.5);
  color: white;
  padding: 10px;
}
 
/* 初始化时显示第一张图片 */
.slider .slide:nth-child(1) {
  transform: translateX(0);
}
 
/* 控制按钮样式 */
.slider-nav {
  text-align: center;
  margin-top: 10px;
}
 
.slider-nav button {
  cursor: pointer;
  border: none;
  background: #ddd;
  padding: 5px 10px;
  margin: 0 5px;
  color: #333;
  font-size: 16px;
}
 
.slider-nav button.active {
  background: #007bff;
  color: white;
}
</style>
</head>
<body>
 
<div class="slider">
  <div class="slide">
    <img src="image1.jpg" alt="Image 1">
    <p>图片 1 的描述文字</p>
  </div>
  <div class="slide">
    <img src="image2.jpg" alt="Image 2">
    <p>图片 2 的描述文字</p>
  </div>
  <div class="slide">
    <img src="image3.jpg" alt="Image 3">
    <p>图片 3 的描述文字</p>
  </div>
</div>
 
<div class="slider-nav">
  <button onclick="changeSlide(1)" class="active">&#10094;</button>
  <button onclick="changeSlide(2)">&#10095;</button>
</div>
 
<script>
let currentSlide = 0;
const slides = document.querySelectorAll('.slide');
const navButtons = document.querySelectorAll('.slider-nav button');
 
function changeSlide(direction) {
  // 移除所有按钮的激活状态
  navButtons.forEach((button) => button.classList.remove('active'));
 
  // 根据方向更新currentSlide的值
  if (direction === 1) {
    currentSlide = (currentSlide + 1) % slides.length;
  } else {
    currentSlide = (currentSlide - 1 + slides.length) % slides.length;
  }
 
  // 为当前导航按钮添加激活状态
  navButtons[currentSlide].classList.add('active');
 
  // 更新所有幻灯片的transform属性
  slides.forEach((slide, index) => {
    slide.style.transform = `translateX(${index - currentSlide}00%)`;
  });
}
</script>
 
</body>
</html>

这个代码实例展示了如何使用JavaScript和CSS3创建一个无缝滚动的图片描述框,用户可以通过点击左右箭头来切换图片。图片描述框使用transform属性进行平滑过渡,而不是直接更改图片位置,这样可以避免网页的重绘重排,提供更流畅的用户体验。

2024-08-20

CSS3的transition属性用于设置一个属性的变化时间。这种变化通常在用户交互(如鼠标悬停或焦点)时发生,但也可以在元素的某个属性改变时自动触发。

基本语法如下:




transition: property duration timing-function delay;
  • property:定义应用过渡的CSS属性名。
  • duration:定义过渡效果的持续时间。
  • timing-function:定义过渡的速度曲线,默认为ease
  • delay:定义过渡效果何时开始,默认是0,意味着过渡效果立即开始。

例子:




div {
  width: 100px;
  height: 100px;
  background-color: blue;
  transition: width 1s ease-in-out;
}
 
div:hover {
  width: 200px;
}

在上面的例子中,当鼠标悬停在div上时,它的宽度会在1秒钟内从100px变为200px,并且会使用ease-in-out的时间曲线。

2024-08-20

在CSS中,选择器用于选定需要应用样式规则的HTML元素。属性是定义样式的值。

以下是一些基本的CSS选择器和属性示例:




/* 元素选择器,选择所有p元素 */
p {
  color: blue; /* 属性:设置文本颜色为蓝色 */
}
 
/* ID选择器,选择id为"header"的元素 */
#header {
  background-color: yellow; /* 设置背景颜色为黄色 */
}
 
/* 类选择器,选择所有class为"highlight"的元素 */
.highlight {
  font-weight: bold; /* 设置字体为粗体 */
}
 
/* 属性选择器,选择所有具有title属性的元素 */
[title] {
  border: 1px solid black; /* 设置边框 */
}
 
/* 伪类选择器,选择所有未被访问的链接 */
a:link {
  color: green; /* 设置文本颜色为绿色 */
}

在HTML中使用这些样式:




<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>CSS Example</title>
<style>
  /* 将上面的CSS代码放在这里 */
</style>
</head>
<body>
 
<p id="header">Header</p>
<p class="highlight" title="This is a paragraph.">This is a paragraph.</p>
<a href="https://www.example.com">Visit Example.com</a>
 
</body>
</html>

以上代码演示了如何在HTML文档中使用CSS来改变文本的颜色、设置背景色、加粗文本、为元素添加边框以及为链接设置颜色。

2024-08-20

CSS3是CSS(层叠样式表)的一个版本,它于2011年被广泛应用于网页设计。CSS3包含许多新特性,例如:

  1. 选择器(Selector):更加丰富和灵活,例如属性选择器、结构性伪类选择器等。
  2. 背景和边框(Background and Border):例如圆角(border-radius)、渐变(gradient)、阴影(box-shadow)等。
  3. 文字效果(Text Effect):例如文字阴影(text-shadow)、字体的放大缩小(font-stretch)等。
  4. 2D/3D转换(Transform):例如旋转(rotate)、缩放(scale)、平移(translate)、倾斜(skew)等。
  5. 动画(Animation):通过关键帧(keyframes)控制动画效果。
  6. 多列布局(Multi-column Layout):可以创建多列的文本布局。
  7. 用户界面(User Interface):例如更多的表单样式(radio、checkbox、select)、滚动条样式(scrollbar)等。
  8. 多媒体(Media Query):可以使网页在不同的设备上有不同的表现。

以下是一个简单的示例,展示了如何使用CSS3中的一些特性:




/* 圆角、渐变背景、阴影 */
div {
  background: linear-gradient(to right, red, yellow);
  border-radius: 10px;
  box-shadow: 5px 5px 10px #888888;
}
 
/* 文字阴影 */
p {
  text-shadow: 2px 2px 4px #888888;
}
 
/* 2D转换:旋转 */
img {
  transform: rotate(45deg);
}
 
/* 多列布局 */
article {
  column-count: 2;
  column-gap: 20px;
}
 
/* 媒体查询:响应式设计 */
@media (max-width: 600px) {
  div {
    border-radius: 5px;
  }
}



<div>This is a div with CSS3 features.</div>
<p>This is a paragraph with CSS3 text effect.</p>
<img src="image.jpg" alt="Rotated Image">
<article>
  <p>This is an article with multi-column layout.</p>
</article>

这个示例展示了如何使用CSS3的一些特性来增强网页的视觉效果和响应式布局。