所以我的功能是:
function onClickChange(props) {
let MyDiv = document.getElementById('myDIV')
let InterfaceDesign = document.getElementById('interfaceDesign')
if (MyDiv.style.display === 'none') {
MyDiv.style.display = ''
InterfaceDesign.classList.add('active')
} else {
MyDiv.style.display = 'none'
InterfaceDesign.classList.remove('active')
}
}
从DOM中的此函数,我可以看到它正在获得活动类。但是从我的样式化组件中:
const FirstDivElement = styled.div`
position: relative;
overflow: hidden;
width: 100%;
background-color: #000;
&:hover {
background-color: #e6007e;
transform: scale(1.05);
}
&:active{
background-color: #e6007e;
}
`
它没有采用&:active的样式
我的div元素是:
<div id="interfaceDesign">
<div onClick={onClickChange}>
<ListItems
headingText="Interface Design"
backgroundImage={props.secondBackgroundImage}
>
<Img
style={{
height: '50px',
width: '50px',
}}
sizes={props.interfacedesign}
/>
</ListItems>
</div>
</div>
<div id="myDIV" style={{ display: 'none' }}>
<InterfaceDesign
secondBackgroundImage={props.secondBackgroundImage}
interfacedesignMagenta={props.interfacedesignMagenta}
/>
</div>
</div>
有人可以帮忙吗?预先谢谢你:D
答案 0 :(得分:0)
您可以通过在active
中传递道具FirstDivElement
并更新onClick
方法来实现。
这里是一个例子:
const FirstDivElement = styled.div`
position: relative;
overflow: hidden;
width: 100%;
background-color: ({ active }) => active ? #e6007e :#000;
&:hover {
background-color: #e6007e;
transform: scale(1.05);
}
&:active{
background-color: #e6007e;
}
`
onClickChange = () => {
let MyDiv = document.getElementById('myDIV')
this.setState({
active: MyDiv.style.display === 'none'
})
}
render(){
const { active } = this.state
return(
<div>
<div onClick={onClickChange}>
{/* content */}
</div>
<FirstDivElement active={active}>
{/* content */}
<div id="myDIV" style={{ display: 'none' }}/>
</FirstDivElement>
<button onClick={this.onClickChange}> Click </button>
</div>
)
}
答案 1 :(得分:0)
您正在为:active pseudo-class提供样式,该样式仅用于激活元素时(例如,在单击鼠标时)。您可能希望在样式化组件CSS中将setValue
更改为&:active
。
此外,您还应该注意,通常会基于带有样式化组件的道具来更改样式。您可以做您正在做的事情,但这并不常见。