CSS3 菱形拼圖實(shí)現(xiàn)只旋轉(zhuǎn)div 背景圖片不旋轉(zhuǎn)功能
需求背景
使用 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)剛開(kāi)始的效果了,完整的 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)文章,希望大家以后多多支持腳本之家!
相關(guān)文章
css3實(shí)現(xiàn)背景圖片顏色修改的多種方式
這篇文章主要介紹了css3實(shí)現(xiàn)背景圖片顏色修改的多種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起2021-04-13CSS3只讓背景圖片旋轉(zhuǎn)180度的實(shí)現(xiàn)示例
這篇文章主要介紹了CSS3只讓背景圖片旋轉(zhuǎn)180度的實(shí)現(xiàn)示例。文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一2021-03-09
前段時(shí)間在開(kāi)發(fā)中,遇到需要給背景層加顏色遮罩的項(xiàng)目,現(xiàn)在特定總結(jié)一下給背景圖層加顏色遮罩的方法,感興趣的朋友跟隨小編一起看看吧2019-11-05
css3實(shí)現(xiàn)一個(gè)div設(shè)置多張背景圖片及background-image屬性實(shí)例演示
這篇文章主要介紹了css3實(shí)現(xiàn)一個(gè)div設(shè)置多張背景圖片及background-image屬性,同時(shí)對(duì)于css3背景漸變也做了詳細(xì)的解釋,水平漸變,左上角漸變等等方式,需要的朋友可以參考下2017-08-10CSS的background屬性及CSS3的背景圖片設(shè)置總結(jié)
這篇文章主要介紹了CSS的background屬性及CSS3的背景圖片設(shè)置總結(jié),背景圖片的顯示區(qū)域和定位是非常值得注意的地方,需要的朋友可以參考下2016-06-13CSS3對(duì)背景圖片的裁剪及尺寸和位置的設(shè)定方法
這篇文章主要介紹了CSS3對(duì)背景圖片的裁剪及尺寸和位置的設(shè)定方法,在IE瀏覽器中要注意一下兼容性,需要的朋友可以參考下2016-03-07多重CSS背景動(dòng)畫(huà)實(shí)現(xiàn)方法示例
CSS背景動(dòng)畫(huà)很長(zhǎng)時(shí)間以來(lái)都是一個(gè)熱門(mén)話題,很多時(shí)候都是因?yàn)樾Ч貏e絢麗,而且不需要額外的技術(shù)。最近有人問(wèn)我是否可以給頁(yè)面上一個(gè)指定的元素安排多重背景動(dòng)畫(huà),答案是y2014-04-04css3實(shí)現(xiàn)背景圖片拉伸效果像桌面壁紙一樣
使用css3 屬性:background-size可以輕松實(shí)現(xiàn)像桌面壁紙一樣拉伸,下面為大家詳細(xì)介紹下具體的相關(guān)實(shí)現(xiàn)過(guò)程,有此需求的朋友可以參考下,希望對(duì)大家有所幫助2013-08-19css3背景圖片透明疊加屬性cross-fade簡(jiǎn)介及用法實(shí)例
據(jù)說(shuō)iOS6系統(tǒng)(iPhone5)增加了兩個(gè)CSS3屬性,一個(gè)是CSS3 filters – CSS3濾鏡另外一個(gè)是CSS3 Cross-fade – CSS3交叉淡入淡出,接下來(lái)為您介紹cross-fade屬性,感興趣的朋友2013-01-08CSS3系列教程:背景圖片(背景大小和多背景圖) 應(yīng)用說(shuō)明
背景圖片/紋理有很多種使用方式,常常用于為添加網(wǎng)站的最佳的界面美化?,F(xiàn)在它在CSS3中被重視,我們可以應(yīng)用多背景圖和背景圖片尺寸來(lái)實(shí)現(xiàn)更完美的效果,需要的朋友可以了解2012-12-19



