• 关于viewWithTag的一点说明


    通常我们使用viewWithTag如下情形:

    如果我们用了一个父View,上面放了多个子view, 每个子view都通过从0开始的Tag值来进行标志,以便于后期在像View上直接使用viewWithTag:tag值来取各个子View

    而在用[父view viewWithTag:0]取到的view, 发现不是子view, 而是这个父view, 

    后来才想起苹果文档上提到过一次,tag值较小的,如0-100为苹果保留使用, 而0就是保留着给自己这个view使用的。

    对于其它的view, 如scrollview, 则更上面的0, 1,2 都可能会是保留值。 

    所以在使用viewWithTag时, 和在设置子view的Tag值时, 需要注意不要使用数值较小的Tag值,使用时建议加一个定值

    #define TileInitialTag          10000

    使用时,如下

    curTileView_0.tag = TileInitialTag + emptyPlaceIndex_0;

    这样就可以有效地避免因为tag值太小,而取到系统保留的view.

    说法二:

    有人在用到viewWithTag的方法时发现了一个Tag的问题于是做了一个小测试:

     
    UIButton *btn = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, 50, 50)];

        btn.backgroundColor = [UIColor blackColor];

        btn.tag = 0;

        [self.mView addSubview:btn];

        [btn release];

        [self.mView viewWithTag:0].backgroundColor = [UIColor whiteColor];

    结果是self.mView的背景颜色变为白色了,调试发现self.mView的tag也为0。查找文档发现UIVIew的默认tag值就是0.而[self.mView viewWithTag:0]会优先查找函数调用者本身的tag,如果函数调用者符合条件就会返回函数调用者本身,所以不能查找到btn。

        现在把代码改一下

    UIButton *btn = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, 50, 50)];

         btn.backgroundColor = [UIColor blackColor];

         btn.tag = 0;

    self.mView.tag = 1;

         [self.mView addSubview:btn];

        [btn release];

         [self.mView viewWithTag:0].backgroundColor = [UIColor whiteColor];

          结果便是btn的背景颜色变为白色,也就是viewWithTag查找到了btn。

    感谢分享

  • 相关阅读:
    APP 元素定位总结(未完待补充)
    vue-axios常见请求配置和全局设置
    vue-axios发送并发请求
    vue-axios基本使用
    vue-vuex-store目录结构
    vue-vuex-modules的基本使用
    vue-vuex-actions的基本使用
    vue-vuex-mutations的类型常量
    vue-vuex-state响应式
    vue-vuex-mutation的提交风格
  • 原文地址:https://www.cnblogs.com/isItOk/p/5346370.html
Copyright © 2020-2023  润新知