モバイルウェブ初日

目標: ディスプレイスメント、スケーリング、回転、グラデーション効果を使用して、Web ページ要素のプレゼンテーションを豊かにします。

01-平面変換

導入

機能: 要素に動的な効果を追加します。通常はトランジションと組み合わせて使用​​されます。

概念: 平面内のボックスの形状を変更する (変位、回転、拡大縮小、傾き)

画像の説明を追加してください

平面変換は2D変換とも呼ばれ、その属性はtransformです。

パン

transform: translate(X轴移动距离, Y轴移动距离);
  • 価値
    • ピクセル単位値
    • パーセンテージ (ボックス自体のサイズに基づいて計算)
    • ポジティブかネガティブかのどちらか
  • スキル
    • translation() は1 つの値のみを書き込みます。これは、X軸に沿って移動することを意味します。
    • X 軸または Y 軸の移動距離を個別に設定します:translateX() または translationY()

中心位置決め

  • 方法 1: マージン

ここに画像の説明を挿入します

  • 方法 2: 翻訳 → ボックス自体のサイズに基づいてパーセンテージが計算されます

ここに画像の説明を挿入します

ケース両開き

ここに画像の説明を挿入します

  • HTML構造
<div class="father">
    <div class="left"></div>
    <div class="right"></div>
</div>
  • CSS スタイル
* {
    
    
    margin: 0;
    padding: 0;
}

/* 1. 布局:父子结构,父级是大图,子级是左右小图 */
.father {
    
    
    display: flex;
    margin: 0 auto;
    width: 1366px;
    height: 600px;
    background-image: url(./images/bg.jpg);

    overflow: hidden;
}

.father .left,
.father .right {
    
    
    width: 50%;
    height: 600px;
    background-image: url(./images/fm.jpg);

    transition: all .5s;
}

.father .right {
    
    
    /* right 表示的取到精灵图右面的图片 */
    background-position: right 0;
}

/* 2. 鼠标悬停的效果:左右移动 */
.father:hover .left {
    
    
    transform: translate(-100%);
}

.father:hover .right {
    
    
    transform: translateX(100%);
}

回転させる

transform: rotate(旋转角度);
  • 値: 角度の単位は度です。
  • スキル
    • 値は正または負のいずれかになります
    • 値が正の場合、時計回りに回転します
    • 値が負の場合は反時計回りに回転します

変換原点

デフォルトでは、変換の原点はボックスの中心点です。

transform-origin: 水平原点位置 垂直原点位置;

価値:

  • 位置名詞(左、上、右、下、中央)
  • ピクセル単位値
  • 割合

ケース-時計

ここに画像の説明を挿入します

.hour {
    
    
  width: 6px;
  height: 50px;
  background-color: #333;
  margin-left: -3px;
  transform: rotate(15deg);
  transform-origin: center bottom;
}

.minute {
    
    
  width: 5px;
  height: 65px;
  background-color: #333;
  margin-left: -3px;
  transform: rotate(90deg);
  transform-origin: center bottom;
}

.second {
    
    
  width: 4px;
  height: 80px;
  background-color: red;
  margin-left: -2px;
  transform: rotate(240deg);
  transform-origin: center bottom;
}

複数の変換

複数の変換テクニック: 最初に平行移動し、次に回転します。

transform: translate() rotate();
  • 多重変換の原理:最初の変換方法の座標軸に基づいてフォームを変換します。
    • 回転すると、Web ページ要素の座標軸が変更されます
    • 最初に回転を記述した場合、後続の変形効果の軸方向は回転後の軸方向に基づき、変形結果に影響します。

ズーム

transform: scale(缩放倍数);
transform: scale(X轴缩放倍数, Y轴缩放倍数);
  • スキル
    • 通常、scale() の値を設定するだけで、X 軸と Y 軸が均等にスケールされることを示します。
    • 1 より大きい値はズームインを意味し、1 未満の値はズームアウトを意味します。

ケースプレイバックの特殊効果

ここに画像の説明を挿入します

  • CSS スタイル
/* 1. 摆放播放按钮:图片区域的中间 */
.box li {
    
    
  overflow: hidden;
}

.pic {
    
    
  position: relative;
}

.pic::after {
    
    
  position: absolute;
  left: 50%;
  top: 50%;
  /* margin-left: -29px;
  margin-top: -29px; */
  /* transform: translate(-50%, -50%); */

  content: '';
  width: 58px;
  height: 58px;
  background-image: url(./images/play.png);
  transform: translate(-50%, -50%) scale(5);
  opacity: 0;

  transition: all .5s;
}
/* 2. hover效果:大按钮,看不见:透明是0 → 小按钮,看得见:透明度1 */
.box li:hover .pic::after {
    
    
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}

傾ける

transform: skew();

値: 角度 度

02-グラデーション

グラデーションとは、複数の色を段階的に変化させる効果で、通常、ボックスの背景を設定するために使用されます。

分類:

  • 線形勾配
    ここに画像の説明を挿入します

  • 放射状グラデーション

ここに画像の説明を挿入します

線形勾配

background-image: linear-gradient(
  渐变方向,
  颜色1 终点位置,
  颜色2 终点位置,
  ......
);

価値:

  • グラデーションの方向: オプション
    • 方向名詞に
    • 角度度
  • 終了位置: オプション
    • 割合

事例・製品展示

ここに画像の説明を挿入します

  • HTML構造
<div class="box">
  <img src="./images/product.jpeg" alt="" />
  <div class="title">OceanStor Pacific 海量存储斩获2021 Interop金奖</div>
  <div class="mask"></div>
</div>
  • CSS スタイル
.mask {
    
    
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(
      transparent,
      rgba(0,0,0,0.5)
  );
  opacity: 0;

  transition: all .5s;
}

.box:hover .mask {
    
    
  opacity: 1;
}

放射状グラデーション

background-image: radial-gradient(
  半径 at 圆心位置,
  颜色1 终点位置,
  颜色2 终点位置,
  ......
);

価値:

  • 半径は 2 で、その場合は楕円になります。
  • 円の中心位置の値:ピクセル単位値/パーセンテージ/方向名詞

03-総合事例

ここに画像の説明を挿入します

ナビゲーションチャンネル

矢印の回転
.x-header-nav .nav-item:hover .icon-down {
    
    
  transform: rotate(-180deg);
}
チャンネルリスト
.channel-layer {
    
    
  position: absolute;
  top: 60px;
  left: 50%;
  z-index: -2;
  width: 1080px;
  height: 120px;
  padding: 10px;
  margin-left: -540px;
  color: #72727b;
  background-color: #f5f5f5;
  border: 1px solid #e4e4e4;
  border-top: none;
  transition: all 0.5s;
  transform: translateY(-120px);
}

/* TODO 2. 弹窗频道 */
.x-header-nav .nav-item:hover .channel-layer {
    
    
  transform: translateY(0);
}

グラデーションボタン

検索ボタン
.x-header-search form .btn {
    
    
  position: absolute;
  top: 0;
  right: 0;
  width: 60px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  background-color: #f86442;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
  background-image: linear-gradient(
    to right,
    rgba(255, 255, 255, 0.3),
    #f86442
  );
}
ログインボタン
/* TODO 7. 渐变按钮 */
.card .card-info .login {
    
    
  padding: 3px 34px;
  color: #fff;
  background-color: #ff7251;
  border-radius: 30px;
  box-shadow: 0 4px 8px 0 rgb(252 88 50 / 50%);
  background-image: linear-gradient(
    to right,
    rgba(255, 255, 255, 0.2),
    #ff7251
  );
}
クライアントボタン
/* TODO 8. 径向渐变 */
.download .dl .dl-btn {
    
    
  width: 68px;
  height: 34px;
  line-height: 34px;
  color: #fff;
  text-align: center;
  border-radius: 4px;
  background-image: radial-gradient(
    50px at 10px 10px,
    rgba(255, 255, 255, 0.5),
    transparent
  );
}

カルーセル

/* TODO 4. 摆放图片 */
.banner .banner-list .banner-item.left {
    
    
  z-index: 0;
  transform: translate(-160px) scale(0.8);
  transform-origin: left center;
}

.banner .banner-list .banner-item.right {
    
    
  z-index: 0;
  transform: translate(160px) scale(0.8);
  transform-origin: right center;
}

あなたも好きかも

/* TODO 5. 播放按钮和遮罩 */
.album-item .album-item-box::after {
    
    
  position: absolute;
  left: 0;
  top: 0;
  content: '';
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,.5) url(../assets/play.png) no-repeat center / 20px;
  opacity: 0;
  transition: all .5s;
}

.album-item .album-item-box:hover::after {
    
    
  opacity: 1;
  background-size: 50px;
}


/* TODO 6. 图片缩放 */
.album-item .album-item-box:hover img {
    
    
  transform: scale(1.1);
}

おすすめ

転載: blog.csdn.net/weixin_44931584/article/details/132995334
おすすめ