React と CSS3 を使用して WeChat で赤い封筒を開けるアニメーション効果を実現する例 (コード)
この記事では主にReactとCSS3を使用してWeChat上で赤い封筒を開くエフェクトの例(コード)を紹介していますので、一定の参考価値があり、興味のある友人は参考にしていただけます。
WeChat の赤い封筒は一連のマーケティングブームを引き起こしましたが、この形式の赤い封筒は誰もがよく知っていると思います。まずエンターテイメントの精神で、ここでは React を使用して、誰でも簡単に赤い封筒を開けるアニメーション効果を実装します。一緒にコミュニケーションして学びましょうCSS3 を使用して赤い封筒を描画します
.redpack { height: 450px; background: #A5423A; width: 300px; left: 0; top: 0; border-radius: 10px; margin: 0 auto; } .topcontent { height: 300px; border: 1px solid #BD503A; background-color: #BD503A; border-radius: 10px 10px 50% 50% / 10px 10px 15% 15%; box-shadow: 0px 4px 0px -1px rgba(0,0,0,0.2); } #redpack-open { width: 100px; height: 100px; border: 1px solid #FFA73A; background-color: #FFA73A; border-radius: 50%; color: #fff; font-size: 20px; display: inline-block; margin-top: -50px; box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.2); }
<p class='redpack'> <!-- 红包的顶部盖子 --> <p class="topcontent"></p> <!-- 拆红包的按钮 --> <p id="redpack-open"></p> </p>
効果は図に示すとおりです:
React を使用してさまざまな 状態を区別します変換
React.jsを使用しますそれを実現するには、主に状態を判断することで、赤い封筒が開封待ちか開封済みかを制御できます。 具体的なコードは以下の通りです
import React from 'react'; class ReadPacket extends React.Component { constructor(props) { super(props); this.state = { animation: false, status: 0 // 0: 等待拆开 1: 拆开后 }; } render() { var bonus = this.props.thanks ? 0 : parseFloat(this.props.surveyInfo.bonus); if(this.state.status == 0) { return ( <p className='redpack-container' id='redpack-container'> <p className='redpack'> <p className='topcontent'> <p id='redpack-opened'> <p className='redpack-avatar'> <img src='http://placehold.it/80x80' alt='头像' width='80' height='80'/> </p> </p> <h2 id="奖励">奖励</h2> <span className='redpack-text'>点击下方按钮领取红包</span> <p className='redpack-description white-text'>恭喜发财 大吉大利</p> </p> <p id='redpack-open' className={this.state.animation ? 'rotate' : ''} onClick={this.openRedPacket.bind(this)} > <span>拆红包</span> </p> </p> </p> ); } else if (bonus == 0) { // 谢谢参与 return ( <p className='redpack-container' id='redpack-container'> <p className='redpack'> <p className='topcontent-open'> <p className='redpack-avatar'> <span id='close'></span> </p> <h1 id="nbsp-谢谢参与-nbsp"> 谢谢参与 </h1> <span className='redpack-text'>多多参与的奖励的机会更多哦</span> <br/> <a onClick={this._toWallet.bind(this)} style={{cursor:'pointer',textDecoration: 'underline', color: 'white'}}> 去我的账户查看 </a> </p> <p id='redpack-opened'> <p className='redpack-avatar'> <img src='http://placehold.it/80x80' alt='头像' width='80' height='80'/> </p> </p> </p> </p> ); } else { // 显示奖励金额 return ( <p className='redpack-container' id='redpack-container'> <p className='redpack'> <p className='topcontent-open'> <p className='redpack-avatar'> <span id='close'></span> </p> <h1 id="nbsp-bonus-toFixed-nbsp"> {bonus.toFixed(2)} </h1> <span className='redpack-text'>奖励积分已经存入您的账户</span> <a className='btn-flat white-text' onClick={this._toWallet.bind(this)} style={{textDecoration: 'underline'}}> 去我的账户查看积分 </a> </p> <p id='redpack-opened'> <p className='redpack-avatar'> <img src='http://placehold.it/80x80' alt='头像' width='80' height='80'/> </p> </p> </p> </p> ); } } stopAnimation() { this.setState({animation: false}); } showResult() { this.setState({status: 1}); } openRedPacket() { this.setState({animation: true}); setTimeout(this.stopAnimation.bind(this), 3000); setTimeout(this.showResult.bind(this), 4000); } _toWallet() { // 跳转到钱包 window.location.hash = '/wallet'; } } export default ReadPacket;
以上がReact と CSS3 を使用して WeChat で赤い封筒を開けるアニメーション効果を実現する例 (コード)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









最近GraphQLの作業を開始した場合、またはその長所と短所をレビューした場合、「GraphQLがキャッシュをサポートしていない」または

Svelte Transition APIは、コンポーネントがカスタムSVELTE遷移を含むドキュメントを入力または離れるときにアニメーション化する方法を提供します。

最近のビットコインの価格が20k $ $ USDを超えており、最近30Kを破ったので、イーサリアムを作成するために深く掘り下げる価値があると思いました

あなたのウェブサイトのコンテンツプレゼンテーションの設計にどれくらいの時間に費やしますか?新しいブログ投稿を書いたり、新しいページを作成したりするとき、あなたは考えていますか

この記事では、影やグラデーションなどのテキスト効果にCSSを使用し、パフォーマンスのために最適化し、ユーザーエクスペリエンスの向上について説明します。また、初心者向けのリソースもリストしています。(159文字)

開発者としての段階に関係なく、私たちが完了したタスクは、大小を問わず、個人的および専門的な成長に大きな影響を与えます。

NPMコマンドは、サーバーの開始やコンパイルコードなどの1回限りのプロセスまたは継続的に実行されるプロセスとして、さまざまなタスクを実行します。
