成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

react-transition-group動畫庫Transition組件使用

charles_paul / 1612人閱讀

摘要:動畫庫這個庫包括個組件,今天做項目剛好用到了組件,記錄一下使用過程中的總結(jié),另外兩個組件用到了再做介紹。規(guī)定完成過渡效果需要多少秒或毫秒。規(guī)定速度效果的速度曲線。參考網(wǎng)址官方案例官網(wǎng)動畫庫的新寫法

react-transition-group動畫庫

這個庫包括3個組件:Transition,CSSTransition,TransitonGroup,今天做項目剛好用到了Transition組件,記錄一下使用過程中的總結(jié),另外兩個組件用到了再做介紹?;蛘咭撇降絩eact 官網(wǎng)動畫庫(react-transition-group)的新寫法

CSS3的transition屬性

該屬性可以對元素里面的一個屬性設(shè)置過渡動畫,比如:transition: width 2s;

祥見:CSS3 transition 屬性

transition-property 規(guī)定設(shè)置過渡效果的 CSS 屬性的名稱。

transition-duration 規(guī)定完成過渡效果需要多少秒或毫秒。

transition-timing-function規(guī)定速度效果的速度曲線。

transition-delay定義過渡效果何時開始。

Transition的屬性

元素動畫在出現(xiàn)和消失時各有3個階段,可以為這些屬性綁定自定義函數(shù):

onEnter:進(jìn)入(出現(xiàn))開始時執(zhí)行

onEntering:進(jìn)入(出現(xiàn))過程中執(zhí)行

onEntered:進(jìn)入(出現(xiàn))結(jié)束執(zhí)行

onExit:離開(消失)時執(zhí)行

onExiting:離開(消失)過程中執(zhí)行

onExited:離開(消失)結(jié)束執(zhí)行

其他屬性介紹:

addEndListener:屬性可以監(jiān)聽出現(xiàn)的3個階段執(zhí)行完成或消失的3個階段執(zhí)行完成時執(zhí)行該函數(shù)監(jiān)聽的自定義函數(shù)。

unmountOnExit:為true 代表退出的時候移除dom,也就是該元素dom動畫執(zhí)行完后直接刪除該元素節(jié)點

appear:渲染的時候就直接執(zhí)行動畫,默認(rèn)false

enter:設(shè)為true后,動畫進(jìn)入(出現(xiàn))的三個階段,前兩個階段onEnter,onEntering先執(zhí)行,然后延遲一段時間再執(zhí)行onEntered,可以簡單的理解為動畫進(jìn)入(出現(xiàn))時有個延遲

exit:設(shè)為true后,動畫離開(消失)的三個階段,前兩個階段onExit,onExiting先執(zhí)行,然后延遲一段時間再執(zhí)行onExited,可以簡單的理解為動畫離開(消失)時有個延遲

timeout:為上面的appear,enter,exit設(shè)置延遲時間

in:動畫進(jìn)入(出現(xiàn)),離開(消失)交替執(zhí)行,點一下動畫生效,再點一下動畫失效

使用方法

標(biāo)簽可是設(shè)置上面那些屬性。標(biāo)簽內(nèi)容包裹一個箭頭函數(shù),該函數(shù)有一個參數(shù)state(參數(shù)名隨意設(shè)置),返回值就是要實現(xiàn)動畫效果的元素,該元素可以設(shè)置style樣式。

案例一

此案例是我測試的案例,通過下拉框的透明度實現(xiàn)一個下拉框出現(xiàn)和消失的效果:

import React from "react";
import {connect} from "react-redux";
//受到路由管控
import {withRouter} from "react-router-dom";
import {Icon} from "antd";
//過渡動畫
import Transition from "react-transition-group/Transition";
//duration設(shè)置延遲時間,下面的timeout屬性使用
const duration = {
         appear:3000,
         enter: 3000,
         exit: 3000};
//默認(rèn)樣式
const  defaultStyle = {
        //ease-in-out規(guī)定以慢速開始和結(jié)束的過渡效果
        transition:`opacity ${3000}ms ease-in-out`,
        opacity:0,
    };
//過渡樣式
const  transitionStyles = {
        //進(jìn)入時2,3階段動畫,如果設(shè)置了延遲時間,會發(fā)現(xiàn)出現(xiàn)時立即透明度百分之"0.5",然后三秒后透明度才為"1"
        //因為延遲時間timeout屬性設(shè)置的``enter:3000``會在第三階段生效
        entering:{opacity: 0.5},
        entered:{opacity:1},
        //離開時2,3階段
        exiting: {opacity: 0.5},
        exited: {opacity: 0}
    };

// 三個進(jìn)入狀態(tài)的事件,可以做你想做的事情
let onEnter = (node, isAppearing) => {
    console.log(isAppearing,node, "onEnter")
};
let onEntering = (node, isAppearing) => {
    console.log(isAppearing,node, "onEntering")
};
let onEntered = (node, isAppearing) => {
    console.log(isAppearing,node,"onEntered")
};

//測試動畫執(zhí)行過程,何時結(jié)束
let done =() => {
    console.log("結(jié)束了")
};

// 三個退出的狀態(tài)的事件
let onExit = (node) => {
    console.log("onExit")
};
let onExiting = (node) => {
    console.log("onExiting")
};
let onExited = (node) => {
    console.log("onExited",node)
};

let addaddEndListener = (node) => { //原生時間transition運動的事件
    node.addEventListener("transitionend", this.done, false);
};

class NavTop extends React.Component{
    constructor(props,context){
        super(props,context);
        this.state = {
          in:false
        };
    }

    render() {
        return 
{/*首頁導(dǎo)航*/}

大魚資源網(wǎng)

{ this.setState({ in:!this.state.in }) }} />
{/*下拉條,過渡動畫*/} { state => { //打印狀態(tài)變化分別是onEnter,onEntering...等6種,通過此處可以看出延遲時間是在第三階段生效,前兩個階段會立即執(zhí)行 console.log(state,"###",{...defaultStyle, ...transitionStyles[state]}, "###"); return
  • 全部課程
  • react課程
  • vue課程
  • 小程序課程
} }
; } } export default withRouter(connect()(NavTop));

案例一結(jié)束。

案例二
//自己簡單的封裝了一個,該有的參數(shù)都由了,可以自行粘貼在自己的代碼里面去試試。
class Fade extends React.Component {
  constructor(props) {
    super(props);
  }
  done =() => {
    // console.log("結(jié)束了")
  }
  addaddEndListener = (node) => { //原生時間transition運動的事件
    node.addEventListener("transitionend", this.done, false);
  }

  // 三個進(jìn)入狀態(tài)的事件,可以做你想做的事情
  onEnter = (node, isAppearing) => {
    console.log(isAppearing, "onEnter")
  }
  onEntering = (node, isAppearing) => {
    console.log(isAppearing, "onEntering")
  }
  onEntered = (node, isAppearing) => {
    console.log(isAppearing, "onEntered")
  }

  // 三個退出的狀態(tài)的事件
  onExit = (node) => {
    console.log("onExit")
  }
  onExiting = () => {
    console.log("onExiting")
  }
  onExited = () => {
    console.log("onExited")
    this.props.self()
  }
  render() {
    const { in: inProp, dur} = this.props;
    const defaultStyle = {
      transition: `transform ${300}ms ease-in-out, opacity ${300}ms ease-in-out`,
      transform: "translateX(100px)",
      opacity: "0"
    }

    const transitionStyles = {
      entering: { transform: "translateX(100px)", opacity: "0"},
      entered:  { transform: "translateX(0px)", opacity: "1" },
      exiting: {transform: "translateX(0px)", opacity: "1"},
      exited: {transform: "translateX(0px)", opacity: "0"}
    };
    const duration = {
      enter: 300,
      exit: 300,
    }
    // 上面的都是基本參數(shù),樣式的轉(zhuǎn)變以及時間的設(shè)定,具體的可以看官網(wǎng)文檔
    // 樣式也可以寫成className 例如
    return (
      
        {
          state => {
            console.log(state, "###") //你可以很直觀的看到組件加載和卸載時候的狀態(tài)
            return(
              
{this.props.children}
) } }
); } }

案例二結(jié)束。

參考網(wǎng)址

官方案例

react官網(wǎng)動畫庫(react-transition-group)的新寫法

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/104053.html

相關(guān)文章

  • react-transition-group畫庫Transition組件使用

    摘要:動畫庫這個庫包括個組件,今天做項目剛好用到了組件,記錄一下使用過程中的總結(jié),另外兩個組件用到了再做介紹。規(guī)定完成過渡效果需要多少秒或毫秒。規(guī)定速度效果的速度曲線。參考網(wǎng)址官方案例官網(wǎng)動畫庫的新寫法 react-transition-group動畫庫 這個庫包括3個組件:Transition,CSSTransition,TransitonGroup,今天做項目剛好用到了Transitio...

    gityuan 評論0 收藏0
  • react 官網(wǎng)畫庫react-transition-group)的新寫法

    摘要:一一個官網(wǎng)提供的動畫過度庫。安裝而官方提供的三個組建。下面來看一個例子效果是增加和刪除列表項中的一個,產(chǎn)生漸入漸失的效果說白了也就是多個或者組合的效果。 一、react-transition-group 一個官網(wǎng)提供的動畫過度庫。 搜索了網(wǎng)上關(guān)于react動畫的,很多的答案都是很久以前的了老版本了,而現(xiàn)在官方提供的是叫react-transition-group 它是以前兩個的合體版本...

    ky0ncheng 評論0 收藏0
  • 讓React應(yīng)用“”起來

    摘要:因為其組件只是根據(jù)提供的及屬性,生成動畫的數(shù)據(jù),業(yè)務(wù)應(yīng)用中拿到生成的數(shù)據(jù)后根據(jù)需要添加需要動畫的組件樣式。除了上述簡單的動畫應(yīng)用,在復(fù)雜動畫的實現(xiàn)方面,表現(xiàn)非常優(yōu)越。 WEB應(yīng)用中動畫很重要 不管是web應(yīng)用還是原生應(yīng)用,也不論是PC端應(yīng)用還是移動端應(yīng)用,動畫都扮演了一個重要的角色。 盡管動畫并不會添加應(yīng)用的實際動能,但一個好的動畫,一個流暢且優(yōu)雅,選擇在恰當(dāng)時機(jī)出現(xiàn)的動畫,能為應(yīng)用增...

    xiyang 評論0 收藏0
  • React畫實現(xiàn)原理

    摘要:動畫的實現(xiàn)原理要實現(xiàn)動畫,究其根本,最終的落地依然是操作從而達(dá)到頁面呈現(xiàn)動畫的目的。 聲明: 當(dāng)前為草稿階段。然后有人可以指引下怎么寫草稿文章么~ web動畫的實現(xiàn)原理 web動畫的實現(xiàn),最終都是需要操作dom。CSS動畫,是給相應(yīng)的dom元素添加動畫className ; JS動畫,則是通過定時器或其他手段,不斷更改dom元素屬性值,達(dá)到動畫的目的。 React動畫的實現(xiàn)原理 Re...

    mrli2016 評論0 收藏0
  • vue內(nèi)置組件——transition簡單原理圖文詳解

    摘要:在元素被插入之前生效,在元素被插入之后的下一幀移除。在整個進(jìn)入過渡的階段中應(yīng)用,在元素被插入之前生效,在過渡動畫完成之后移除。這個類可以被用來定義進(jìn)入過渡的過程時間,延遲和曲線函數(shù)。版及以上定義進(jìn)入過渡的結(jié)束狀態(tài)。 基本概念 Vue 在插入、更新或者移除 DOM 時,提供多種不同方式的應(yīng)用過渡效果 在 CSS 過渡和動畫中自動應(yīng)用 class 可以配合使用第三方 CSS 動畫庫,如...

    lingdududu 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<