iOS解决警告: Attribute Unavailable: Automatic Preferred Max Layout Width before iOS 8.0

前言

优秀的开发者在看到每一个警告当做一个报错去看待、认真去对待解决!在开发中难免都会遇到很多意想不到的警告,但是希望我们每个开发者都能用看待一个问题一样去理解并解决它,只有这样我们才能得到更快的进步。
今天我给大家分享几个经常遇到的警告解决方法,以及使用预编译指令忽略掉一些警告的方法等。

1.解决xib版本警告

项目警告:Attribute Unavailable: Automatic Preferred Max Layout Width before iOS 8.0 、

image.png

此警告来源于使用xib或者storyboard开发时出现的!先解释一下此警告,其警告意思是: 我们要在 iOS8之前 设置 自动换行的最大宽度。 由于我们项目有做兼容 iOS7、然后在 xib中 正好有个 label 或者 button。我们只要设置了其 line , 只要使其行数 不为 1,然后还兼容了 iOS7的话 都会弹出此警告 。因为在 iOS8之前系统要求我们要设置 preferredMaxLayoutWidth 此属性。 此属性的意思就是字体每一行宽度最大多少时自动换行。
解决方法有三种:

一.

我们直接在 xib设置控件的属性 lines将其改成1 , 然后在到代码中设置其行数即可! 警告直接消失。

二.

我们可以这样直接到Xib中去设置preferredMaxLayoutWidth 此属性即可, 看图


选择控件的尺寸设置,然后把Explicit勾勾划上, 此时系统会自动按Label总长度算出一个最大宽度, 如果觉得不标准我们可以自行在计算一次! 说明一下 此宽度是一个最大换行的宽度,如果我们设置的宽度超出控件的宽度其并不会影响到控件换行。

考虑到不同屏幕的适配,我们直接设置一个固定的宽度必然是会出现问题的,布局使用AutoLayout来做, 在iPhone4 中Label可能是 200,到了 iPhone 7中可能又变成了 240, 然后我们如果直接按照 iPhone 4的去 给一个最大宽度,会导致出现的问题就是, 由于控件的宽度已经固定好了。 其换行的时候肯定会变高。然后由于其长度是 240 但是我们设置最大自动换行为 200, 虽然我们看到控件的问题并不会有什么明显的不同。但是我们可以打开可视化 界面, 会发现我们的 Label变的比我们所填写的内容还要高一些 。 因为系统按我们设置的 最大 换行高度去计算出Label 高度,但是其在填充内容的时候 会自动填满一行之后才进行换行, 所以我们如果设置自动换行太小,会影响到我们的 Label 真实的高度。 虽然视觉上是看不出来,但是如果我们使用 AutoLayout布局 ,然后正好 Label 上面一个控件于其有依赖关系 ,本来只是 5个像素距离 ,然后运行后可能变成了 15。 解决方法: 我们可以直接按照 最大机型去填写 自动换行 宽度 即可!

三.

第二种方法设置完之后总感觉有点怪怪的,怕设置自动换行高度填写错导致一些异样不到的错误。那我们可以看下第三种方法。
相对更靠谱的方法就是勾选完设置自动换行之后在代码中添加代码去重新计算其最大宽度 如在控制器中
-(void)viewDidLayoutSubviews
{
[super viewDidLayoutSubviews];
self.tipsLabel.preferredMaxLayoutWidth = self.tipsLabel.bounds.size.width;
}
在View中

  • (void)layoutSubviews
    {
    [super layoutSubviews];
    self.tipsLabel.preferredMaxLayoutWidth = self.tipsLabel.bounds.size.width;
    }
    这样等 控件布局结束 得到其真实宽高之后,在拿来设置一次 其 最大的换行 宽度是最合理的!

2.pragam 使用预处理指令 忽略警告

先引入 三个宏定义

//#pragam clang diagnostic push
//#pragam clang diagnostic ignored "-Wno-nonnull" “此处填写的时次警告的类型”
//#pragam clang diagnostic pop

解释一下这三个预处理指令含义, 第一条是告诉编译器 开始执行忽警告, 第二条是把要忽略的警告类型 告诉编译器 , 编译器会自动帮我们忽略掉 我们要进行忽略的警告, 第三条则是关闭警告的忽略。
不过此处最麻烦的就是我们不知道当前警告的类型 。 之前我也挺纠结此事 后面找到这篇文章, 里面有很多相关警告的类型 http://fuckingclangwarnings.com/ 我们可以通过 警告的 一些关键字来查找一下 对应的类型。

3. 禁止三方库所有警告

有时候我们引入一些三方库,总是有很多乱七八糟的警告。 直接在项目的 Podfile 文件中添加 此段代码 即可全部忽略掉。 inhibit_all_warnings! #禁止掉警告 不是很推荐 只是有时候对于一些强迫症者来说看到一条警告都会受不了的

结尾

总感觉少了挺多相关内容,关于警告有很多解决的技巧,由于时间等关系,等自己有空了在过来稍作补充,如有错误的地方麻烦大家帮忙指出,谢谢大家!

学习的路上, 与君共勉!!!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容