学习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绑定

选中控件,在右侧的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和控制器的方法,其他控件也类似。

小生入门,有何不对之处,还望指出。_

最新文章

  1. CI框架多个表前缀,如何使用框架语句querybuilder
  2. poj3304Segments(直线与多条线段相交)
  3. [置顶] 我的设计模式学习笔记------&gt;Java设计模式总概况
  4. HTML5之缓存
  5. (转)BAT及各大互联网公司2014前端笔试面试题--Html,Css篇
  6. 仿小米网jQuery全屏滚动插件fullPage.js
  7. program_options禁止命令行短参数
  8. c++11-bind的用法
  9. jfinal使用jstl表达的存在的问及解决
  10. UE4 custom depth 自定义深度
  11. 【一天一道LeetCode】#43. Multiply Strings
  12. PAT1034;Head of a Gang
  13. 【PHP版】火星坐标系 (GCJ-02) 与百度坐标系 (BD-09ll)转换算法
  14. input(type=&quot;checkbox&quot;|type=&quot;radio&quot;)+jquery使用
  15. linux 编译静态库及动态库例子--from周立功文档
  16. semantic-ui 标题
  17. POJ 1017 最少包裹
  18. springboot 修改页面不重启
  19. 【SqlServer】SqlServer中的更新锁(UPDLOCK)
  20. vi/vim 按键说明

热门文章

  1. tsar采集数据原理
  2. js判断当前移动设备平台
  3. 训练1-V
  4. [tyvj-1071]LCIS 动态规划
  5. [NoiPlus2016]天天爱跑步
  6. 找不到javax.servlet.http.HttpServletResponse和javax.servlet.http.HttpServletRequest
  7. maven项目发布后访问jsp页面报错
  8. centos查看防火墙端口
  9. C++ auto类型说明符
  10. java陷阱之spring事物未提交和回滚导致不可预知问题