react實(shí)現(xiàn)一個(gè)優(yōu)雅的圖片占位模塊組件詳解
前言
發(fā)現(xiàn)項(xiàng)目中的圖片占位模塊寫得很不優(yōu)雅,找了一圈,發(fā)現(xiàn)沒找到自己想要的圖片組件。于是自己寫了一個(gè),寫了一個(gè)還算優(yōu)雅的圖片組件:mult-transition-image-view
截圖:

功能簡(jiǎn)介
首先它是一個(gè)比較優(yōu)雅的組件:用起來不頭疼。
第二個(gè)它能實(shí)現(xiàn)以下場(chǎng)景:
- 沒有圖片的時(shí)候,顯示一個(gè)占位圖(可以直接用css來寫背景,方便自定義)
- 希望在加載大圖的時(shí)候,能先占位一張小圖,然后再過渡到一張大圖。類似上面的截圖。
使用方法
安裝npm 包
npm install react-mult-transition-image-view
代碼部分
import ImageBoxView from 'react-mult-transition-image-view' <ImageBoxView img="#你的圖片#"/>
當(dāng)然 你可以設(shè)置其他屬性
<ImageBoxView width="320" // height="200" // 寬高,會(huì)轉(zhuǎn)化成 style 屬性 mode="style" // 使用 style 去顯示圖片(默認(rèn):img) img="#你要的圖片#"/> // 圖片路徑
小圖過渡到大圖的效果
<ImageBoxView
animate="fade" // 會(huì)觸發(fā)動(dòng)畫樣式(見下方樣式部分 )
mode="style" // 使用 style 去顯示圖片(默認(rèn):img)
img={['#小圖地址#', '#大圖地址#']}/> // img 傳入數(shù)組形式。
實(shí)現(xiàn)隨機(jī)顯示圖片
當(dāng)有很多圖片的時(shí)候,可以讓圖片隨機(jī)時(shí)間顯示,增加圖片顯示出來的體驗(yàn)
(一起出來真的有點(diǎn)丑)
<ImageBoxView delay="100" // 延遲加載(默認(rèn):0),可以傳入一個(gè)隨機(jī)數(shù) img="#你要的圖片#"/> // 圖片路徑
幻燈片效果
因?yàn)?img 屬性可以傳入數(shù)組,所以 理論上可以加載很多圖,實(shí)現(xiàn)幻燈片效果。
使用 wait 屬性 來設(shè)置,每張圖片加載后的等待時(shí)間
<ImageBoxView
animate="fade" // 會(huì)觸發(fā)動(dòng)畫樣式(見下方樣式部分 )
wait="100" // 每張圖片加載完后,繼續(xù)加載下一張的時(shí)間(默認(rèn):0)
mode="style" // 使用 style 去顯示圖片(默認(rèn):img)
img={['#圖片1#', '#圖片2#', '#圖片3#']}/> // img 傳入數(shù)組形式。
樣式部分
別忘了樣式部分
.c-img-box{
display:inline-block;
width: 320px;
height: 200px;
background: #f7f6f5;
position: relative;
.img-hold{
overflow: hidden;
background-size: cover;
background-repeat: no-repeat;
background-position: center;
img{
width:100%;
height:100%;
}
&.img-animate{
transition: opacity 0.5s;
}
}
.img-cover{
background: url('https://d.2dfire.com/om/images/menulist/7deb58da.default.png') no-repeat center/300px;
background-color:#f0f0f0;
}
.img-cover,
.img-hold,
.img-hide{
position: absolute;
width: 100%;
height: 100%;
top:0;
left:0;
}
.img-hide{
opacity: 0;
}
}
TODO
github: https://github.com/qilei0529/react-mult-transition-image-view
本地下載:http://xiazai.jb51.net/201710/yuanma/react-mult-transition-image-view(jb51.net).rar
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
React Hooks常用場(chǎng)景的使用(小結(jié))
這篇文章主要介紹了React Hooks常用場(chǎng)景的使用,根據(jù)使用場(chǎng)景分別進(jìn)行舉例說明,幫助你認(rèn)識(shí)理解并可以熟練運(yùn)用 React Hooks 大部分特性,感興趣的可以了解一下2021-04-04
詳解React Native開源時(shí)間日期選擇器組件(react-native-datetime)
本篇文章主要介紹了詳解React Native開源時(shí)間日期選擇器組件(react-native-datetime),具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09
React和Vue中實(shí)現(xiàn)錨點(diǎn)定位功能
在React中,可以使用useState和useEffect鉤子來實(shí)現(xiàn)錨點(diǎn)定位功能,在Vue中,可以使用指令來實(shí)現(xiàn)錨點(diǎn)定位功能,在React和Vue中實(shí)現(xiàn)錨點(diǎn)定位功能的方法略有不同,下面我將分別介紹,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
關(guān)于React16.0的componentDidCatch方法解讀
這篇文章主要介紹了關(guān)于React16.0的componentDidCatch方法解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
React中使用Axios發(fā)起POST請(qǐng)求提交文件方式
這篇文章主要介紹了React中使用Axios發(fā)起POST請(qǐng)求提交文件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
React Router 中實(shí)現(xiàn)嵌套路由和動(dòng)態(tài)路由的示例
React Router 是一個(gè)非常強(qiáng)大和靈活的路由庫,它為 React 應(yīng)用程序提供了豐富的導(dǎo)航和 URL 管理功能,能夠幫助我們構(gòu)建復(fù)雜的單頁應(yīng)用和多頁應(yīng)用,這篇文章主要介紹了React Router 中如何實(shí)現(xiàn)嵌套路由和動(dòng)態(tài)路由,需要的朋友可以參考下2023-05-05

