React styled-components設(shè)置組件屬性的方法
問(wèn)題
最近在試著用react做一個(gè)音樂(lè)播放器,在這之前其實(shí)并不了解styled-components,但由于使用css in js并且想實(shí)現(xiàn)hover效果,百度各種解決方案后發(fā)現(xiàn)了styled-components這個(gè)好東西,如果你看到了這篇博客,就證明你應(yīng)該了解或者熟練運(yùn)用styled-components了。
回到項(xiàng)目開發(fā)中,一個(gè)音樂(lè)播放器應(yīng)該由多個(gè)組件組成,其中有一個(gè)list組件用于展示歌曲列表,就像這樣
鵝。。。好像暴露了我的喜好。。。
每一列就是一個(gè)div(當(dāng)然ul也是可以的),為了方便后續(xù)功能的實(shí)現(xiàn),我把每首歌的海報(bào)、音頻文件的地址當(dāng)做div的屬性儲(chǔ)存起來(lái)。list組件的代碼如下
import React from 'react'; import styled from 'styled-components'; // 設(shè)置樣式 const ContentDiv = styled.div` display: flex; justify-content: space-between; height: 50px; line-height: 50px; transition: 0.5s; cursor: pointer; &:hover{ color: #31c27c; } `; const LengthDiv = styled.div` color: #999; `; // list組件 class List extends React.Component { constructor(props){ super(props); this.state = { // 播放列表 list: this.props.list }; } render(){ const listItem = this.state.list.map((item, index) => { return ( <ContentDiv key={ item.name } poster={ item.poster } audio={ item.music }> <div> { item.name } - { item.author } </div> <LengthDiv> { item.length } </LengthDiv> </ContentDiv> ); }); return ( <div> { listItem } </div> ) } } export default List;
代碼很簡(jiǎn)單,但最后我們會(huì)發(fā)現(xiàn)這樣一個(gè)問(wèn)題——在頁(yè)面中生成的div元素只有poster屬性而沒(méi)有audio屬性
打開react developer tools查看
這時(shí)可以發(fā)現(xiàn)其實(shí)并不是styled.div直接編譯成原生html元素,而是會(huì)生成一個(gè)div(當(dāng)然,如果是styled.button就會(huì)額外生成一個(gè)子button),最后在頁(yè)面中顯示的就是這個(gè)div。
也可以發(fā)現(xiàn)在styled.div中兩個(gè)屬性都是設(shè)置好的,但在子div中就只有一個(gè)屬性了,通過(guò)反復(fù)嘗試可以發(fā)現(xiàn),直接在styled-components組件中設(shè)置屬性,除了className之外就只有一個(gè)屬性會(huì)生效
解決
解決的辦法就是多看幾遍styled-components文檔,我們就會(huì)發(fā)現(xiàn)styled-components有一個(gè)attr方法來(lái)支持為組件傳入 html 元素的其他屬性,那么原來(lái)的list組件就只需要修改ContentDiv變量即可
const ContentDiv = styled.div.attrs({ poster: props => props.poster, audio: props => props.audio })` display: flex; justify-content: space-between; height: 50px; line-height: 50px; transition: 0.5s; cursor: pointer; &:hover{ color: #31c27c; } `;
props對(duì)象就是我們傳入ContentDiv的屬性,這樣一來(lái),最后生成的div中poster與audio屬性都有。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React Draggable插件如何實(shí)現(xiàn)拖拽功能
這篇文章主要介紹了React Draggable插件如何實(shí)現(xiàn)拖拽功能問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07react-router-dom入門使用教程(前端路由原理)
這篇文章主要介紹了react-router-dom入門使用教程,主要包括react路由相關(guān)理解,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08React倒計(jì)時(shí)功能實(shí)現(xiàn)代碼——解耦通用
這篇文章主要介紹了React倒計(jì)時(shí)功能實(shí)現(xiàn)——解耦通用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09react拖拽react-beautiful-dnd一維數(shù)組二維數(shù)組拖拽功能
二維數(shù)組可以拖拽,但是不可以編輯+拖拽,如果想要實(shí)現(xiàn)編輯+拖拽,還是需要轉(zhuǎn)換成一維數(shù)組,本文給大家介紹react拖拽react-beautiful-dnd的相關(guān)知識(shí),感興趣的朋友跟隨小編一起看看吧2024-03-03使用React?SSR寫Demo一學(xué)就會(huì)
這篇文章主要為大家介紹了使用React?SSR寫Demo實(shí)現(xiàn)教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06React實(shí)現(xiàn)簡(jiǎn)單登錄的項(xiàng)目實(shí)踐
登錄、注冊(cè)、找回密碼是前端項(xiàng)目經(jīng)常遇到的需求,本文主要介紹了React實(shí)現(xiàn)簡(jiǎn)單登錄的項(xiàng)目實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01react中的useImperativeHandle()和forwardRef()用法
這篇文章主要介紹了react中的useImperativeHandle()和forwardRef()用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08react中的useContext具體實(shí)現(xiàn)
useContext是React提供的一個(gè)鉤子函數(shù),用于在函數(shù)組件中訪問(wèn)和使用Context,useContext的實(shí)現(xiàn)原理涉及React內(nèi)部的機(jī)制,本文給大家介紹react中的useContext具體實(shí)現(xiàn),感興趣的朋友一起看看吧2023-11-11