藍橋杯 web 展開你的扇子(css3)


普通答案:

#box:hover #item1{transform: rotate(-60deg);
}
#box:hover #item2{transform: rotate(-50deg);
}
#box:hover #item3{transform: rotate(-40deg);
}
#box:hover #item4{transform: rotate(-30deg);
}
#box:hover #item5{transform: rotate(-20deg);
}
#box:hover #item6{transform: rotate(-10deg);
}
#box:hover #item12{transform: rotate(60deg);
}
#box:hover #item11{transform: rotate(50deg);
}
#box:hover #item10{transform: rotate(40deg);
}
#box:hover #item9{transform: rotate(30deg);
}
#box:hover #item8{transform: rotate(20deg);
}
#box:hover #item7{transform: rotate(10deg);
}

1. 選擇器解析

#box:hover #item6 {transform: rotateZ(-10deg);
}
(1)?#box:hover
  • #box?是一個 ID 選擇器,表示選中 HTML 中?id="box"?的元素。
  • :hover?是一個偽類,表示當用戶將鼠標懸停在該元素上時應用樣式。
  • #box:hover?的意思是:當鼠標懸停在?id="box"?的元素上時,觸發相關的樣式規則。
(2)?#item6
  • #item6?是另一個 ID 選擇器,表示選中 HTML 中?id="item6"?的元素。
  • #box:hover #item6?表示:當鼠標懸停在?#box?上時,選中?#box?內部的?#item6?元素。

2. 樣式規則

transform: rotateZ(-10deg);
(1)?transform?屬性
  • transform?是一個 CSS 屬性,用于對元素進行變換操作(如旋轉、縮放、移動等)。
  • 在這里,transform?被用來對?#item6?進行旋轉。
(2)?rotateZ(-10deg)
  • rotateZ?是?transform?的一個函數,表示圍繞 Z 軸旋轉。
  • -10deg?表示逆時針旋轉 10 度(負值為逆時針,正值為順時針)。
  • 因此,rotateZ(-10deg)?的意思是:讓?#item6?元素圍繞 Z 軸逆時針旋轉 10 度。

?如果你不指定旋轉軸(如 rotateX, rotateY, 或 rotateZ),則默認是圍繞 Z 軸進行旋轉。這意味著單獨使用 rotate 實際上等同于 rotateZ


擴展:js 做法

box.onmouseover = () => { 
for(let i = 1; i <=6; i++ ) {
let item = document.querySelector(`#item${i}`) item.style.transform = `rotate(${-60+(i-1)*10}deg)`
console.log(item) } for(let i = 7; i <=12; i++ ) {
let item = document.querySelector(`#item${i}`) item.style.transform = `rotate(${(i-6)*10}deg)` 
console.log(item) }

代碼逐行解析

1.?box.onmouseover = () => { ... }
  • 這是一個事件綁定,表示當用戶將鼠標懸停在?box?元素上時,執行后面的箭頭函數。
  • onmouseover?是原生 DOM 的事件屬性,類似于?addEventListener('mouseover', ...)
2. 第一個?for?循環
for (let i = 1; i <= 6; i++) {let item = document.querySelector(`#item${i}`);item.style.transform = `rotate(${-60 + (i - 1) * 10}deg)`;console.log(item);
}
(1)?for (let i = 1; i <= 6; i++)
  • 循環從?i = 1?開始,到?i = 6?結束,總共循環 6 次。
  • 每次循環處理一個?#itemX?元素(#item1?到?#item6)。
(2)?let item = document.querySelector(#item${i})
  • 使用模板字符串?`#item${i}`?動態生成選擇器,例如:
    • 當?i = 1?時,選擇器為?#item1
    • 當?i = 2?時,選擇器為?#item2
  • document.querySelector?返回匹配該選擇器的第一個 DOM 元素。
(3)?item.style.transform = rotate(${-60 + (i - 1) * 10}deg)``
  • 設置?item?元素的?transform?樣式,使其旋轉一定的角度。
  • -60 + (i - 1) * 10?是一個數學表達式,用于計算旋轉角度:
    • 當?i = 1?時:-60 + (1 - 1) * 10 = -60,即旋轉?-60deg
    • 當?i = 2?時:-60 + (2 - 1) * 10 = -50,即旋轉?-50deg
    • 當?i = 3?時:-60 + (3 - 1) * 10 = -40,即旋轉?-40deg
    • 以此類推,直到?i = 6?時,旋轉角度為?-10deg
(4)?console.log(item)
  • 打印當前處理的?item?元素,方便調試和查看是否正確選擇了目標元素。
3. 第二個?for?循環
for (let i = 7; i <= 12; i++) {let item = document.querySelector(`#item${i}`);item.style.transform = `rotate(${(i - 6) * 10}deg)`;console.log(item);
}
(1)?for (let i = 7; i <= 12; i++)
  • 循環從?i = 7?開始,到?i = 12?結束,總共循環 6 次。
  • 每次循環處理一個?#itemX?元素(#item7?到?#item12)。
(2)?let item = document.querySelector(#item${i})
  • 同第一個循環,動態生成選擇器并獲取對應的 DOM 元素。
(3)?item.style.transform = rotate(${(i - 6) * 10}deg)``
  • 設置?item?元素的?transform?樣式,使其旋轉一定的角度。
  • (i - 6) * 10?是一個數學表達式,用于計算旋轉角度:
    • 當?i = 7?時:(7 - 6) * 10 = 10,即旋轉?10deg
    • 當?i = 8?時:(8 - 6) * 10 = 20,即旋轉?20deg
    • 當?i = 9?時:(9 - 6) * 10 = 30,即旋轉?30deg
    • 以此類推,直到?i = 12?時,旋轉角度為?60deg
(4)?console.log(item)
  • 同第一個循環,打印當前處理的?item?元素。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/75118.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/75118.shtml
英文地址,請注明出處:http://en.pswp.cn/web/75118.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

LLM驅動的智能體:基于GPT的對話智能體開發指南

前言 大語言模型&#xff08;LLM, Large Language Model&#xff09;正在徹底改變智能體&#xff08;Agent&#xff09;的設計和實現方式。從簡單的聊天機器人到復雜的自動化助手&#xff0c;基于GPT等LLM的對話智能體已經在客服、教育、辦公自動化、編程助手等領域得到了廣泛…

深度解析 C# 中介者模式:設計與實戰應用

中介者模式&#xff08;Mediator Pattern&#xff09;是一種行為型設計模式&#xff0c;其核心思想是將多個對象之間的交互集中到一個中介者對象中&#xff0c;從而減少對象之間的直接交互&#xff0c;降低耦合度。在實現復雜系統時&#xff0c;中介者模式有助于提高系統的可維…

每日算法-250408

記錄今天解決的兩道 LeetCode 算法題&#xff0c;主要涉及二分查找的應用。 1283. 使結果不超過閾值的最小除數 題目描述 思路 核心思路是 二分查找。 解題過程 為什么可以使用二分&#xff1f; 關鍵在于單調性。對于一個固定的數組 nums&#xff0c;當除數 divisor 增大時&…

MySQL的子查詢

一、前言 MySQL 子查詢是指嵌套在其他 SQL 語句&#xff08;如 SELECT、WHERE、FROM 等&#xff09;內部的查詢。用于輔助主查詢完成復雜的數據篩選或計算。 二、子查詢分類 標量子查詢 描述&#xff1a;返回 單行單列&#xff08;一個值&#xff09;&#xff0c;常用于比較運…

Linux 基礎入門操作 前言 VIM的基本操作 2

1 VIM的背景介紹 Vi 的誕生與1976年&#xff0c;Vim 的前身是 Vi&#xff08;Visual Editor&#xff09;&#xff0c;由 Bill Joy 在 BSD Unix 系統上開發&#xff0c;作為 ed&#xff08;行編輯器&#xff09;的改進版本&#xff0c;提供全屏編輯功能&#xff0c;成為 Unix/L…

Java:Set操作

目錄 Set 轉 List Set 轉 List Set<String>set new HashSet<String>(); set.add("c"); set.add("d"); set.add("a"); set.add("a");//方法一&#xff1a; List<String>list new ArrayList<String>(set);//…

算力驅動未來:從邊緣計算到高階AI的算力革命

算力驅動未來&#xff1a;從邊緣計算到高階AI的算力革命 摘要 本文深入探討了不同算力水平&#xff08;20TOPS至160TOPS&#xff09;在人工智能領域的多樣化應用場景。從邊緣計算的實時目標檢測到自動駕駛的多傳感器融合&#xff0c;從自然語言處理的大模型應用到AI for Scie…

虛擬機上安裝openEuler和openGauss數據庫

1.虛擬機版本選擇VM 16 PRO 2.openEuler版本選擇openEuler-22.03-LTS-SP4-x86_64 下載地址&#xff1a;https://mirrors.aliyun.com/openeuler/openEuler-22.03-LTS-SP4/ISO/x86_64/openEuler-22.03-LTS-SP4-x86_64-dvd.iso 3.虛擬機安裝openEuler過程&#xff1a; 4.安裝ope…

0_Pytorch中的張量操作

[引言]張量的概念 1.基本概念 張量是一個通用的多維數組&#xff0c;可以表示標量&#xff08;0 維&#xff09;、向量&#xff08;1 維&#xff09;、矩陣&#xff08;2 維&#xff09;以及更高維度的數據。張量是 PyTorch 中的核心數據結構&#xff0c;用于表示和操作數據。…

LS-LINUX-002 簡易創建SSH

LS-LINUX-002 簡易創建SSH 1. CentOS 8 創建和配置SSH服務 1.1 安裝SSH服務 CentOS 8 默認已經安裝了OpenSSH服務。如果沒有安裝&#xff0c;可以使用以下命令安裝&#xff1a; sudo dnf install -y openssh-server1.2 啟動SSH服務 安裝完成后&#xff0c;需要啟動SSH服務…

計算機專業求職面試的常見題目分類整理

以下是計算機專業求職面試的常見題目分類整理&#xff0c;每個大類精選20道高頻問題&#xff0c;結合參考內容進行解析與擴展&#xff0c;幫助系統化備考&#xff1a; 一、數據結構與算法 解釋時間復雜度和空間復雜度 時間復雜度衡量算法執行時間隨輸入規模的增長趨勢&#xf…

腳本啟動 Java 程序

如果你想在后臺啟動一個 Java 程序&#xff0c;并在終端窗口中顯示一個自定義的名字&#xff0c;可以通過編寫一個簡單的腳本來實現。以下是一個基于 Linux/macOS 的解決方案&#xff0c;使用 Bash 腳本啟動 Java 程序&#xff0c;并在終端窗口中顯示自定義標題。 示例腳本 創建…

CentOS禁用nouveau驅動

1、驗證 nouveau 是否在運行 lsmod | grep nouveau如果命令返回結果&#xff0c;說明 nouveau 驅動正在運行。 2、編輯黑名單文件 通過編輯黑名單配置文件來禁用 nouveau 驅動&#xff0c;這樣在系統啟動時不會加載它。 vi /etc/modprobe.d/blacklist-nouveau.conf修改以下…

Linux: network: tcpdump: packets dropped by kernel

文章目錄 最近遇到一個問題原因libpcap/tcpdump 接口linux/libpcap 接口內核的處理原因可能有以下幾種:解決方法:man pcap_stats最近遇到一個問題 tcpdump命令顯示有dropped的包,而且是被內核drop的。 [root@-one-01 ~]# tcpdump -i any udp and port 8080 -v -w /root/udp…

WEB安全--提權思路

一、情形 在我們成功上傳webshell到服務器中并拿到權限時&#xff0c;發現我們的權限很低無法執行特定的命令&#xff0c;這時為了能做更多的操作&#xff0c;我們就需要提升權限。 二、方式 2.1、Windows提權 1、普通用戶執行systeminfo命令獲取服務器的基本信息&#xff0…

001 vue

https://cn.vuejs.org/ 文章目錄 v-bindv-modelv-on修飾符條件渲染/控制&#xff1a;v-if v-show列表渲染 M&#xff1a;即Model&#xff0c;模型&#xff0c;包括數據和一些基本操作 V&#xff1a;即View&#xff0c;視圖&#xff0c;頁面渲染結果 VM&#xff1a;即View-Mode…

Tomcat 負載均衡

目錄 二、Tomcat Web Server 2.1 Tomcat 部署 2.1.1 Tomcat 介紹 2.1.2 Tomcat 安裝 2.2 Tomcat 服務管理 2.2.1 Tomcat 啟停 2.2.2 目錄說明 2.2.3編輯主頁 2.3 Tomcat管理控制臺 2.3.1開啟遠程管理 2.3.2 配置遠程管理密碼 三、負載均衡 3.1 重新編譯Nginx 3.1.1 確…

使用SpringSecurity下,發生重定向異常

使用SpringSecurity下&#xff0c;發生空轉異常 環境信息&#xff1a; Spring Boot 3.4.4 &#xff0c; jdk 17 &#xff0c; springSecurity 6.4.4 問題背景&#xff1a; 沒有自定義controller &#xff0c;改寫了login 頁面&#xff0c;并且進行了成功后的跳轉處理&#xf…

S130N-ISI 全棧方案與云平臺深度協同:重構 PLC 開發新范式

一、什么是 PLC&#xff1f; 1.技術定義 PLC&#xff08;Power Line Communication&#xff09;是一種創新的通信技術&#xff0c;它以電力線作為天然的傳輸介質&#xff0c;通過先進的信號調制技術將高頻數據信號疊加于工頻電流之上&#xff0c;實現電力輸送與數據通信的雙頻共…

SU-YOLO:基于脈沖神經網絡的高效水下目標檢測模型解析

論文地址:https://arxiv.org/pdf/2503.24389 目錄 一、論文概述 二、創新點解析 1. 基于脈沖的水下圖像去噪(SpikeDenoiser) 原理與結構 2. 分離批歸一化(SeBN) 原理與結構 3. 優化的殘差塊(SU-Block) 原理與結構 三、代碼復現指南 環境配置 模型訓練 四、…