濮阳杆衣贸易有限公司

主頁 > 知識庫 > CSS3 菱形拼圖實現(xiàn)只旋轉div 背景圖片不旋轉功能

CSS3 菱形拼圖實現(xiàn)只旋轉div 背景圖片不旋轉功能

熱門標簽:廣西房產(chǎn)智能外呼系統(tǒng)推薦 電話機器人鑰匙扣 地圖標注位置怎么弄圖 漯河外呼調(diào)研線路 400電話唐山辦理 旅游地圖標注線路 電銷專用外呼線路 電銷外呼系統(tǒng)是違法的嗎 威力最大的電銷機器人

需求背景

使用 vue 做的項目,業(yè)務需求有一個拼圖效果,默認是深色的背景圖,上面分五個區(qū)域,每次會亮一個區(qū)域,整張圖都亮,拼圖完成。先來看一下最終的效果圖。

應用到的知識點:

  • background-size
  • background-position
  • transform:rotate

實現(xiàn)思路:

外層大盒子用來放暗色背景圖,里面的5塊拼圖,是5個div,每塊拼圖都使用背景定位的方式展示背景圖的固定區(qū)域,中間的拼圖做了旋轉。但是旋轉后,又遇到了個問題:背景圖片也跟著旋轉了,像下面這樣:


 

解決背景旋轉的思路:可以在第5塊拼圖的外層套一個盒子,將外層盒子向右旋轉45度,再將背景的元素向左旋轉45度。操作完又發(fā)現(xiàn)了新的問題,下面圖中的黑色邊框是外層盒子(為了方便看,把其他的拼圖塊都設置為不可見)。如果給外層盒子設置 overflow:hidden ,那么中間拼圖的上下左右四個角都會缺失。

我們需要把第五塊拼圖的寬高設置大一些,再設置它外層的盒子 overflow:hidden。寬高設置大的話,對應的 background-size 也要改變。


 

最后,就可以實現(xiàn)剛開始的效果了,完整的 vue 代碼如下:

<template>
    <section class="box">
        <div class="bg" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
        <div v-if="item1Show" class="item item1" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
        <div v-if="item2Show" class="item item2" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
        <div v-if="item3Show" class="item item3" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
        <div v-if="item4Show" class="item item4" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
        <div v-if="item5Show" class="item item5wrap">
            <div class="item5" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
        </div>
    </section>
</template>
<script>
import bgImg from "@/assets/bg.jpeg";
export default {
    data() {
        return {
            bgImg,
            item1Show: false,
            item2Show: true,
            item3Show: true,
            item4Show: true,
            item5Show: true
        };
    }
};
</script>
<style lang="less">
@borderColor: #333;
.box {
    margin: 0px auto;
    width: 300px;
    height: 200px;
    background-color: #000;
    position: relative;
    .bg {
        width: 100%;
        height: 100%;
        position: absolute;
        left: 0;
        top: 0;
        background-position: center center;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        opacity: 0.5;
    }
    .item {
        width: 50%;
        height: 50%;
        box-sizing: border-box;
        background-size: 200% 200%;
        border-right: 1px solid @borderColor;
        border-bottom: 1px solid @borderColor;
        position: absolute;
    }
    .item1 {
        background-position: 0 0;
        left: 0;
        top: 0;
    }
    .item2 {
        background-position: 100% 0;
        left: 50%;
        top: 0;
    }
    .item3 {
        background-position: 0 100%;
        left: 0;
        top: 50%;
    }
    .item4 {
        background-position: 100% 100%;
        left: 50%;
        top: 50%;
    }
    .item5wrap {
        width: 100px;
        height: 100px;
        border-left: 1px solid @borderColor;
        border-top: 1px solid @borderColor;
        transform: rotate(45deg);
        left: 50%;
        top: 50%;            
        transform: translate(-50%, -50%) rotate(45deg);
        overflow: hidden;
        .item5 {
            width: 150px;
            height: 150px;
            background-position: 50% 50%;
            background-size: 200% 133%;
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%) rotate(-45deg);
        }
    }
}
</style>

到此這篇關于CSS3 菱形拼圖實現(xiàn)只旋轉div 背景圖片不旋轉功能的文章就介紹到這了,更多相關CSS3旋轉圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持腳本之家!

標簽:欽州 試駕邀約 綏化 焦作 銅陵 湘西 無錫 湖北

巨人網(wǎng)絡通訊聲明:本文標題《CSS3 菱形拼圖實現(xiàn)只旋轉div 背景圖片不旋轉功能》,本文關鍵詞  CSS3,菱形,拼圖,實現(xiàn),只,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《CSS3 菱形拼圖實現(xiàn)只旋轉div 背景圖片不旋轉功能》相關的同類信息!
  • 本頁收集關于CSS3 菱形拼圖實現(xiàn)只旋轉div 背景圖片不旋轉功能的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    北票市| 普兰店市| 涪陵区| 抚远县| 锦州市| 滁州市| 娄烦县| 尚义县| 阳新县| 南川市| 文成县| 阿合奇县| 体育| 桂平市| 崇文区| 平潭县| 阳原县| 大庆市| 青阳县| 天峨县| 罗平县| 邳州市| 津市市| 垣曲县| 察雅县| 介休市| 呼图壁县| 嘉义县| 博罗县| 广河县| 镶黄旗| 玛曲县| 鹿邑县| 邵武市| 巍山| 兴义市| 航空| 武冈市| 桐乡市| 厦门市| 夏邑县|