統(tǒng)一設(shè)置 " 返回 " 按鈕

方法一 : 在 NavigationController 中, 重寫父類的push方法

/**
* 攔截所有push進來的子控制器
* @param viewController 每一次push進來的子控制器
*/
- (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated
{
  //    if (不是第一個push進來的子控制器) {
  if (self.childViewControllers.count >= 1) {
      // 左上角的返回
      UIButton *backButton = [UIButton buttonWithType:UIButtonTypeCustom];
      [backButton setTitle:@"返回" forState:UIControlStateNormal];
      [backButton setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
      [backButton setTitleColor:[UIColor redColor] forState:UIControlStateHighlighted];
      [backButton setImage:[UIImage imageNamed:@"navigationButtonReturn"] forState:UIControlStateNormal];
      [backButton setImage:[UIImage imageNamed:@"navigationButtonReturnClick"] forState:UIControlStateHighlighted];
      [backButton sizeToFit];
      [backButton addTarget:self action:@selector(back) forControlEvents:UIControlEventTouchUpInside];
      backButton.contentEdgeInsets = UIEdgeInsetsMake(0, -20, 0, 0);
      viewController.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:backButton];
      viewController.hidesBottomBarWhenPushed = YES; // 隱藏底部的工具條
  }

  // super的push方法一定要寫到最后面
  // 一旦調(diào)用super的pushViewController方法,就會創(chuàng)建子控制器viewController的view
  // 也就會調(diào)用viewController的viewDidLoad方法
  [super pushViewController:viewController animated:animated];
}
- (void)back
{
  [self popViewControllerAnimated:YES];
}

方法二 : 在BaseViewController 中, 寫一個 - (void)setupNavigationwithTitle:(NSString *)title; 方法, 然后, 在需要 "返回" 按鈕的頁面, 調(diào)用此方法.

/**
 *  設(shè)置navigationbar的title(同時還默認的包含有設(shè)置返回按鈕為黑色)
 *
 *  @param title title的內(nèi)容
 */
- (void)setupNavigationwithTitle:(NSString *)title;

- (void)setupNavigationwithTitle:(NSString *)title {
    
    UIButton *backBtn = [UIButton buttonWithType:UIButtonTypeCustom];
    backBtn.frame = CGRectMake(0.0, 0.0, 80.0, 40.0);
    UIImageView *backImg = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"back_black"]];
    backImg.frame = CGRectMake(-14.0, 2.0, 30.0, 40.0);
    [backBtn addSubview:backImg];
    
    UILabel *backLabel = [[UILabel alloc]init];
    backLabel.text = @"返回";
    backLabel.textColor = [UIColor whiteColor];
    backLabel.font = [UIFont systemFontWithSize:16.0f];
    backLabel.frame = CGRectMake(10, 2.0, 40, 40);
    
    [backBtn addSubview:backLabel];
    
    [backBtn addTarget:self
                action:@selector(btnItemClick)
      forControlEvents:UIControlEventTouchUpInside];
    UIBarButtonItem *leftButton = [[UIBarButtonItem alloc] initWithCustomView:backBtn];
    [self.navigationItem setLeftBarButtonItem:leftButton];
    
    self.title = title;
    
}
- (void)btnItemClick
{
    [self.navigationController popViewControllerAnimated:YES];

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市雇毫,隨后出現(xiàn)的幾起案子桨啃,更是在濱河造成了極大的恐慌,老刑警劉巖砚嘴,帶你破解...
    沈念sama閱讀 211,743評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件十酣,死亡現(xiàn)場離奇詭異,居然都是意外死亡际长,警方通過查閱死者的電腦和手機耸采,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來工育,“玉大人虾宇,你說我怎么就攤上這事∪绯瘢” “怎么了嘱朽?”我有些...
    開封第一講書人閱讀 157,285評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長怔接。 經(jīng)常有香客問我搪泳,道長,這世上最難降的妖魔是什么扼脐? 我笑而不...
    開封第一講書人閱讀 56,485評論 1 283
  • 正文 為了忘掉前任岸军,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘凛膏。我一直安慰自己杨名,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,581評論 6 386
  • 文/花漫 我一把揭開白布猖毫。 她就那樣靜靜地躺著台谍,像睡著了一般。 火紅的嫁衣襯著肌膚如雪吁断。 梳的紋絲不亂的頭發(fā)上趁蕊,一...
    開封第一講書人閱讀 49,821評論 1 290
  • 那天,我揣著相機與錄音仔役,去河邊找鬼掷伙。 笑死,一個胖子當(dāng)著我的面吹牛又兵,可吹牛的內(nèi)容都是我干的任柜。 我是一名探鬼主播,決...
    沈念sama閱讀 38,960評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼沛厨,長吁一口氣:“原來是場噩夢啊……” “哼宙地!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起逆皮,我...
    開封第一講書人閱讀 37,719評論 0 266
  • 序言:老撾萬榮一對情侶失蹤宅粥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后电谣,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體秽梅,經(jīng)...
    沈念sama閱讀 44,186評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,516評論 2 327
  • 正文 我和宋清朗相戀三年剿牺,在試婚紗的時候發(fā)現(xiàn)自己被綠了企垦。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,650評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡晒来,死狀恐怖竹观,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情潜索,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布懂酱,位于F島的核電站竹习,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏列牺。R本人自食惡果不足惜整陌,卻給世界環(huán)境...
    茶點故事閱讀 39,936評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧泌辫,春花似錦随夸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至殿遂,卻和暖如春诈铛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背墨礁。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評論 1 266
  • 我被黑心中介騙來泰國打工幢竹, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人恩静。 一個月前我還...
    沈念sama閱讀 46,370評論 2 360
  • 正文 我出身青樓焕毫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親驶乾。 傳聞我的和親對象是個殘疾皇子邑飒,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,527評論 2 349

推薦閱讀更多精彩內(nèi)容

  • 1.自定義控件 a.繼承某個控件 b.重寫initWithFrame方法可以設(shè)置一些它的屬性 c.在layouts...
    圍繞的城閱讀 3,367評論 2 4
  • *面試心聲:其實這些題本人都沒怎么背,但是在上海 兩周半 面了大約10家 收到差不多3個offer,總結(jié)起來就是把...
    Dove_iOS閱讀 27,131評論 30 470
  • 轉(zhuǎn)至元數(shù)據(jù)結(jié)尾創(chuàng)建: 董瀟偉,最新修改于: 十二月 23, 2016 轉(zhuǎn)至元數(shù)據(jù)起始第一章:isa和Class一....
    40c0490e5268閱讀 1,690評論 0 9
  • (一) 記憶中,那片長著青苔的石階上唇牧,總坐著一個光頭的老頭兒和一個光頭的小孩兒罕扎。老頭兒總是拿著一根煙桿和一些葉子煙...
    北極毛毛蟲閱讀 389評論 15 5
  • 現(xiàn)實就是這樣殘忍的東西,它總在你不能察覺的時候丐重,一點一點摧毀你的信仰腔召,摧毀你以為自己可以給出的承諾“绲耄——《致我們終...
    棠棣樹閱讀 189評論 0 1