关于layoutIfNeeded


对于layoutIfNeeded本人浅谈下自己的理解,首先我们要了解为何在用到用到constraint的动画时以下代码无法实现动画的功能:

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    
    [UIView animateWithDuration:2.0 animations:^{
      
       self.blueViewH.constant = 80;
    }];
}

而我们直接使用frame的时候动画是可以实现的:

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    
    [UIView animateWithDuration:2.0 animations:^{
        
        CGRect  size =self.blueView.frame;
        
        size.size.height = 80;
        
        self.blueView.frame = size;
        
    }];
}

说明,我们所调用的方法是正确的,那么我们可以大胆的假设"self.blueViewH.constant = 80;"在这句赋值并没有在该方法中完成,从而导致动画并没有实现;而要进行Constraint动画则需要对NSLayoutConstraint的对象赋值之后调用layoutIfNeeded方法才能实现动画(由于Xcode改版后调用layoutIfNeeded方法只会刷新子控件键,因此要使用必须通过它的父类):

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    
    self.blueViewW.constant = 80;
    
    [UIView animateWithDuration:2.0 animations:^{
  
        [self.view layoutIfNeeded];
    }];
}

通过两个能够实现动画的代码比较,我们就可以推测出NSLayoutConstraint的本质就是在系统底层转换为frame,并且NSLayoutConstraint的转换还不是在你赋值的时候就转换完成,而是极可能在某一方法结束后才进行转换;因此我们调用layoutIfNeeded方法对"self.blueViewW.constant = 80;"代码进行强制刷新的时候便能实现该动画了.

总之,layoutIfNeeded在需要重新布局的时候立即刷新进行重新布局,不受其他因素影响.


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



猜您在找
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM