|  | @@ -28,12 +28,19 @@ class TabPane extends PureComponent<TabPaneProps> {
 | 
											
												
													
														|  |      ref = createRef<HTMLDivElement>();
 |  |      ref = createRef<HTMLDivElement>();
 | 
											
												
													
														|  |      _active: boolean;
 |  |      _active: boolean;
 | 
											
												
													
														|  |      context: TabContextValue;
 |  |      context: TabContextValue;
 | 
											
												
													
														|  | -    firstRender: boolean = true;
 |  | 
 | 
											
												
													
														|  | 
 |  | +    rendered: boolean = true;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      componentDidMount(): void {
 |  |      componentDidMount(): void {
 | 
											
												
													
														|  |          this.lastActiveKey = this.context.activeKey;
 |  |          this.lastActiveKey = this.context.activeKey;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +    componentDidUpdate(prevProps: Readonly<TabPaneProps>, prevState: any, snapshot?: any) {
 | 
											
												
													
														|  | 
 |  | +        // CATION: be careful of the tabPane state update
 | 
											
												
													
														|  | 
 |  | +        // Animation only play while it is not first rendering process.
 | 
											
												
													
														|  | 
 |  | +        // Update states multiple times in TabPane will cause children unwanted re-rendering and unwanted animation.
 | 
											
												
													
														|  | 
 |  | +        this.rendered = false; 
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      // get direction from current item key to activeKey
 |  |      // get direction from current item key to activeKey
 | 
											
												
													
														|  |      getDirection = (activeKey: string, itemKey: string, panes: Array<PlainTab>): boolean => {
 |  |      getDirection = (activeKey: string, itemKey: string, panes: Array<PlainTab>): boolean => {
 | 
											
												
													
														|  |          if (itemKey !== null && activeKey !== null && Array.isArray(panes) && panes.length) {
 |  |          if (itemKey !== null && activeKey !== null && Array.isArray(panes) && panes.length) {
 | 
											
										
											
												
													
														|  | @@ -63,7 +70,7 @@ class TabPane extends PureComponent<TabPaneProps> {
 | 
											
												
													
														|  |      };
 |  |      };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      render(): ReactNode {
 |  |      render(): ReactNode {
 | 
											
												
													
														|  | -        const { tabPaneMotion: motion, tabPosition, isFirstRender } = this.context;
 |  | 
 | 
											
												
													
														|  | 
 |  | +        const { tabPaneMotion: motion, tabPosition } = this.context;
 | 
											
												
													
														|  |          const { className, style, children, itemKey, ...restProps } = this.props;
 |  |          const { className, style, children, itemKey, ...restProps } = this.props;
 | 
											
												
													
														|  |          const active = this.context.activeKey === itemKey;
 |  |          const active = this.context.activeKey === itemKey;
 | 
											
												
													
														|  |          const classNames = cls(className, {
 |  |          const classNames = cls(className, {
 | 
											
										
											
												
													
														|  | @@ -102,7 +109,7 @@ class TabPane extends PureComponent<TabPaneProps> {
 | 
											
												
													
														|  |                  x-semi-prop="children"
 |  |                  x-semi-prop="children"
 | 
											
												
													
														|  |              >
 |  |              >
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -                <CSSAnimation motion={motion && active && !isFirstRender} animationState={active ? "enter" : "leave"}
 |  | 
 | 
											
												
													
														|  | 
 |  | +                <CSSAnimation motion={motion && active && !this.rendered} animationState={active ? "enter" : "leave"}
 | 
											
												
													
														|  |                      startClassName={startClassName}>
 |  |                      startClassName={startClassName}>
 | 
											
												
													
														|  |                      {
 |  |                      {
 | 
											
												
													
														|  |                          ({ animationClassName, animationEventsNeedBind }) => {
 |  |                          ({ animationClassName, animationEventsNeedBind }) => {
 |