首页 > 解决方案 > onClick 动画不触发

问题描述

所以我遇到的问题是,这里我有一个 pushLogic,所以我想要实现的是,当我按下按钮时,我想开始动画,我想让微调器开始旋转,但由于某种原因它不是正在做。

  const [spinnerOne, setSpinnerOne] = useState(true);

  const push= ()=>{ 
    setSpinnerOne(true)
    setTimeout(()=>{
     history.push('/')
    },3000)
 
 }
  return (
     <div>
       <span className={spinnerOne  ? `spinnerOne` :''}></span>
       <button onClick={push} ></button>
    </div>

css


@keyframes spinnerOne {
  to {
    transform: rotate(360deg);
  }
}
.spinnerOne:before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100px;
  height: 100px;
  margin-top: -120px;
  margin-left: -50px;
  border-radius: 50%;
  border: 5px solid #b409ca;
  border-top-color: #3500c8;
  border-right-color: rgb(221, 7, 0);
  border-bottom-color: rgb(246, 98, 0);
  animation: spinnerOne 2s linear infinite
}

标签: javascriptcssreactjs

解决方案


您需要将 spinner css 类与动画 css 类分开,并应用动画类 onClick。

export default function App() {
   const [spinnerOne, setSpinnerOne] = useState(false);

  const push= ()=>{ 
    setSpinnerOne(true)
    setTimeout(()=>{
     //history.push('/')
    },3000)
 
 }
  return (
     <div>
       <span className={spinnerOne  ? `spinner spinnerOne` :'spinner'}></span>
       <button onClick={push} >Click me</button>
    </div>
  )
}

css

.spinner:before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100px;
  height: 100px;
  margin-top: -120px;
  margin-left: -50px;
  border-radius: 50%;
  border: 5px solid #b409ca;
  border-top-color: #3500c8;
  border-right-color: rgb(221, 7, 0);
  border-bottom-color: rgb(246, 98, 0);
}

.spinnerOne:before {
  animation: spinnerOne 2s linear infinite
}

https://stackblitz.com/edit/react-bvcnru?file=src/App.js


推荐阅读