濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > CSS3 菱形拼圖實(shí)現(xiàn)只旋轉(zhuǎn)div 背景圖片不旋轉(zhuǎn)功能

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

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

需求背景

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

應(yīng)用到的知識(shí)點(diǎn):

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

實(shí)現(xiàn)思路:

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


 

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

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


 

最后,就可以實(shí)現(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>

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

標(biāo)簽:欽州 試駕邀約 綏化 焦作 銅陵 湘西 無(wú)錫 湖北

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《CSS3 菱形拼圖實(shí)現(xiàn)只旋轉(zhuǎn)div 背景圖片不旋轉(zhuǎn)功能》,本文關(guān)鍵詞  CSS3,菱形,拼圖,實(shí)現(xiàn),只,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《CSS3 菱形拼圖實(shí)現(xiàn)只旋轉(zhuǎn)div 背景圖片不旋轉(zhuǎn)功能》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于CSS3 菱形拼圖實(shí)現(xiàn)只旋轉(zhuǎn)div 背景圖片不旋轉(zhuǎn)功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    海兴县| 靖江市| 淮安市| 安陆市| 绥化市| 宁国市| 宽甸| 宜君县| 长宁县| 资兴市| 吉林省| 永胜县| 中牟县| 东丰县| 莱阳市| 枞阳县| 湖北省| 兴安盟| 同心县| 阿拉善右旗| 桦南县| 枣阳市| 伊吾县| 庄浪县| 嵩明县| 大姚县| 开江县| 安陆市| 攀枝花市| 晋宁县| 栖霞市| 福州市| 鄂托克前旗| 乌鲁木齐县| 宝兴县| 宁阳县| 木里| 铜鼓县| 南雄市| 邳州市| 芮城县|