IOS入門之創建視圖和控制項綁定

来源:http://www.cnblogs.com/jiy-for-you/archive/2017/05/23/6892354.html
-Advertisement-
Play Games

學習IOS幾天了,跟著教程做了兩個小應用了,現在先來總結一下。今天就是創建視圖和綁帶到代碼了。其實就是常見的MVC模式實現。 使用的Xcode版本是8.2。 在Xcode創建項目之後,預設就會創建一個Main.stroyborad,程式的入口也就是這裡,可以在 General 的 Deploymen ...


學習IOS幾天了,跟著教程做了兩個小應用了,現在先來總結一下。今天就是創建視圖和綁帶到代碼了。其實就是常見的MVC模式實現。

使用的Xcode版本是8.2。

在Xcode創建項目之後,預設就會創建一個Main.stroyborad,程式的入口也就是這裡,可以在GeneralDeployment Info里的Main Interface修改入口storyboard為其他的。

在項目的目錄中還能看見自動創建的ViewController類,其實就是一個ViewController對應一個界面。控制項庫中自帶了幾個ViewController,新建項目時,Single View Application 就是創建一個空白的ViewController。Tabbed Application就是創建一個Tab Bar Controller。

~~

在MVC模式中

* M -- 數據模型
* V -- View 對應這裡的storyboard上的界面
* C -- Controller 對應這裡的ViewController類
  • 通過storyboard,我們設計界面,然後通過制定界面控制項和ViewController類的關係,達到View和Controller綁定。
  • 通過storyboard,還可以設計界面間的跳轉segue
  • 上圖中的ViewController就是整個storyboard的root view controller

創建好擺放控制項界面之後,就可以開始擺放控制項和將控制項遇ViewController綁定了

1 擺放控制項

將控制項從控制項庫,拖動到界面上就ok。

2 設置控制項樣式

選中控制項,在右側的inspector面板里選擇button的類型、狀態、標題、文字顏色、文字大小等屬性

3 將控制項與controller綁定

connect inspector

選中控制項,在右側的connection inspector面板中,可以看見button的連接屬性

  • Triggered Segues 這個action連接到一個界面時,點擊button就將調轉到連接的界面
  • Outlet Collections button將作為一個屬性集合的一員
  • Sent Events 當button的不同點擊事件觸發時,連接到上面的方法就被觸發
  • Refrencing Outlets button作為一個類的屬性,一般就是button所在界面的ViewController類的屬性

button可以作為類屬性的同時,將自己的事件與類的方法綁定;也可製作為屬性,或者只綁定事件。

4 開始操作

有2種方式,可以進行綁定

  • 1 在controller類里定義屬性和方法,再手動綁定
    • 1

      button的屬性: @property(nonatomic,weak)IBOutlet UIButton* button;
      button的事件: - (IBAction)clickButton:(id)sender;
    • 2 在button的connection inspector面板中,將屬性或事件綁定到button屬性和clickButton方法上
    • 3 綁定之後,就能屬性是和View Controller綁定的;touch up side 事件是和View Controller里的clickButton方法綁定的

~~

  • 2 自動綁定,好安逸。選中button所在的佈局,然後點擊Xcode右上角的assistan editor。確保是在ViewController.h文件,如果不是可以在頂部切換到。接著滑鼠按著button + Ctrl,往interface區中拖,按圖那樣操作,就能實現綁定。

~~

經過上述的操作之後,我們就能點擊界面中間的button,做些事情了。
最終控制器里的代碼,加一句點擊button就修改button的文字。

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController

@property (weak, nonatomic) IBOutlet UIButton *button;

- (IBAction)clickButton:(id)sender;

@end

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
}

- (IBAction)clickButton:(id)sender {
    //修改button文字
    [self.button setTitle:@"clicked!" forState:UIControlStateNormal];
}

@end

~~

以上就是在storyboard里綁定Button和控制器的方法,其他控制項也類似。

小生入門,有何不對之處,還望指出。^_^


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 文檔對象模型(Document Object Model,DOM)是使用 W3C 定義的 API (Application Program Interface) 來操作 HTML 文檔 (此處不局限於 HTML,亦可操作 XHTML、XML 等),使用戶可以與進行頁面交互。 它使用對象的表示方式來表 ...
  • 在JavaScript中,回調函數具體的定義為:函數A作為參數(函數引用)傳遞到另一個函數B中,並且這個函數B執行函數A。我們就說函數A叫做回調函數。如果沒有名稱(函數表達式),就叫做匿名回調函數。 callback 不一定用於非同步,一般同步(阻塞)的場景下也經常用到回調,比如要求執行某些操作後執行 ...
  • 一、水平居中設置-行內元素 1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>定寬塊狀元素水平居中</title> 6 <style> 7 div{ 8 border:1px solid red; 9 marg ...
  • 用一周多的時間做了一個簡易的wap站 之前研究過webpack但是一直沒用過,這次公司要做一個h5網站,正好拿來練練手,話說angular1x對移動端不是很友好,但主要是angular1x比較熟悉,上手快,開發也快,就沒去考慮其他前端mvc框架。 好了webpack出了中文版以後,對於我們這些英語不 ...
  • vue安裝 將來我們不同的項目可能會用到不同的node版本,那麼就需要在各個node版本之間切換,所以建議使用nvm進行node版本控制。 安裝nvm: 前往https://github.com/coreybutler/nvm-windows下載,雙擊打開 點擊下一步: 第一個路徑XX/node/n ...
  • for-of迴圈: 新語法如下: 它的優點是: 這是目前遍曆數組最簡潔和直接的語法; 它避免了for-in的所有缺陷; 與forEach()不一樣,它支持break,continue和return。 for-of迴圈不僅僅是為遍曆數組而設計的。基本上所有類數組對象都適用 它也能用在字元串上,它將字元 ...
  • 一,效果圖。 二,代碼。 ...
  • 先回顧生命周期 Activity一共有3中狀態 運行中 Activity位於前臺,並具有用戶焦點 暫停 另一個Activity位於屏幕前臺並具有用戶焦點,但此Activity仍可見。也就是說,另一個Activity顯示在此Activity上方,並且該Activity部分透明或未覆蓋整個屏幕。暫停的A ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...