打开Xcode

选择项目模板

  • Single View Application是最适合初学者的模板

设置项目属性

运行程序

  • 不管怎样,先运行第一个iOS程序看看效果先(用快捷键Command + R 也行)

运行结果

  • Xcode会启动一个iOS模拟器来运行程序
  • 程序的运行结果如右图所示,白白一片
  • 后面我们得往这空白界面上增添各种各样的控件元素

窥探项目环境

  • 项目创建完毕后,自动帮我们做了很多配置,也自动生成了很多文件
  • 还自动添加了开发所依赖的框架:

如何搭建UI界面

  • 项目中这么多文件,哪些是影响着UI界面的呢?
  • 在iOS5之前,苹果使用xib文件来描述UI界面
  • 在iOS5之后,苹果采取了更加强大和先进的storyboard文件来描述界面(Xcode5是基于iOS7的)
  • 因此,可以得出结论:
  • 修改项目中的Main.storyboard文件就可以修改UI界面

窥探Main.storyboard

  • 打开Main.storyboard文件一看,里面有一个全白的界面
  • 其实这个界面就是模拟器上显示的界面
  • 左边的箭头表明:程序一启动就会显示箭头所指的界面

显示工具栏

  • 要想往storyboard的界面中添加其他控件,得显示工具栏

显示控件库

  • 以九宫格形式展示控件库,能同时看到更多的控件
  • 从右图中可以看到各种各样的控件,比如按钮、标签、文本输入框等等

添加控件

  • 鼠标左键,长按右边的某个控件,即可将它拖拽到左边的白色界面上

修改控件属性

  • 单击选中某个控件后,可以在右边的菜单工具栏中更改控件的属性

运行效果

  • 运行程序可以发现,软件界面基本搭建完毕,也能通过键盘输入数字了

增加监听按钮的方法

  • 打开MJViewController.m,在类扩展中增加方法声明

@interface MJViewController ()

// 这里先把IBAction看做是

void - (IBAction)compute;

@end

  • 在.m中声明的方法是私有方法,外界无法直接访问,保证了封装性
  • 增加方法实现:

@implementation MJViewController

- (void)compute

{

NSLog(@"点击了计算按钮");

}

@end

建立 按钮 与 方法 的联系

  • 接下来,就是建立按钮和compute方法之间的关系
  • 先点击storyboard,然后点击“中分”按钮

  • 现在已经能同时看到storyboard上的按钮 和 compute方法了,接下来建立它们之间的联系

  • 按住Control键,用鼠标左键将按钮拖线到compute方法上,然后松开

  • 方法左边的圈圈由空心变为实心,说明已经跟某个按钮进行了连线
  • 就这样,点击“计算”按钮,就会自动调用compute方法了

运行程序

  • 重新运行程序后,点击“计算”按钮,会发现控制台已经有输出信息

增加控件属性

  • 现在已经能够监听按钮的点击事件了,接下来应该在MJViewController的compute方法拿到两个文本框值,然后把计算结果显示到最右边的文本标签
  • 在类扩展中,声明3个属性,用来访问storyboard中的3个控件

  1. @property (nonatomic, weak) IBOutlet UITextField *number1;
  2. @property (nonatomic, weak) IBOutlet UITextField *number2;
  3. @property (nonatomic, weak) IBOutlet UILabel *result;
  • 提醒
  1. IBOutlet和weak的作用会在后面解释

  2. 初学者最容易犯、最不应该犯的一个错误:钻牛角尖

建立 控件 和 属性 的联系

  • 按住Control键,用鼠标左键将控件拖到对应属性上,然后松开
  • 利用MJViewController的number1属性就能访问第1个文本框;

  • 利用MJViewController的number2属性就能访问第2个文本框;

  • 利用MJViewController的result属性就能访问右边的文本标签。

计算和

  • 在compute方法中计算两个文本框的和,将结果显示到右边的标签中
  1. - (void)compute

  2. {

  3. // 获取第一个数值

  4. int num1 = [self.number1.text intValue];

  5. // 获取第二个数值

  6. int num2 = [self.number2.text intValue];

  7. // 设置文本标签的值

  8. self.result.text = [NSString stringWithFormat:@"%d", num1 + num2];

  9. }

UI控件 和 控制器的关系

02-第一个iOS程序-开发步骤的更多相关文章

  1. [IOS]从零开始搭建基于Xcode7的IOS开发环境和免开发者帐号真机调试运行第一个IOS程序HelloWorld

    首先这篇文章比较长,若想了解Xcode7的免开发者帐号真机调试运行IOS程序的话,直接转到第五部分. 转载请注明原文地址:http://www.cnblogs.com/litou/p/4843772. ...

  2. ios程序开发杂记

    ios程序开发杂记 一.程序构建 与一般的程序构建无太大区别,都是源文件编译链接这一套,通常是在mac上做交叉编译,也就是利用xcode里带的ios编译工具集去生成arm架构的ios程序(或是x86的 ...

  3. 从安装Mac OS X虚拟机到第一个IOS程序

    对于纯粹地抄这种行为是比较抵触的,别人已经写得挺好的东西没必要又去写一遍,但如果不写经验来看下次再做时自己又要重复百度筛选一遍,所以还是要记一记. 之前要获取IOS静态库的版本,但一直以来没有Mac没 ...

  4. 02-第一个iOS程序

    第一个iOS程序 第一个iOS程序简介 初学iOS开发,研究的程序不要过于复杂,应该从最基本的开始 大房子都是由小砖一块一块堆成的,而大型app是由无数个小程序段组成的 接下来实现一个简单的“加法计算 ...

  5. iOS开发系列--IOS程序开发概览

    概览 终于到了真正接触IOS应用程序的时刻了,之前我们花了很多时间去讨论C语言.ObjC等知识,对于很多朋友而言开发IOS第一天就想直接看到成果,看到可以运行的IOS程序.但是这里我想强调一下,前面的 ...

  6. 第一个iOS程序:Hello iOS

    今天我们来创建第一个iOS程序:Hello iOS!不需要写任何代码就能实现:

  7. 轻量级应用开发之(01)第一个IOS程序

    一 IPhone轻量级开发 1. 开发环境 Mac 版本: OS X EICap 10.11.3 (15D21) XCode开发版本: Version 7.2.1 (7C1002) 2.简单分析 UI ...

  8. IOS程序开发中-跳转到 发送短信界面 实现发短信

    前言:我发现我标题取的不好,谁帮我取个承接上下文的标题?评论一下,我改 项目需求:在程序开发中,我们需要在某个程序里面发送一些短信验证(不是接收短信验证,关于短信验证,传送门:http://www.c ...

  9. iOS 程序开发

    准备 iOS 开发 之 编程知识点 iOS 程序调试 iOS 之 OC开发实战 iOS 架构模式 iOS 之 新功能.扩展

随机推荐

  1. 4、加载:Loading

    /* ---html----*/ <ion-content> <button (click)="manual()">手动关闭</button> ...

  2. HashTable 元素的查找

    Hashtable 特点:键与值成对存在,键是唯一的,不能重复.在查找元素的时候,我们往往是依据键区查找值的 三种方法 contains   包含 containsKey containsValue ...

  3. 针对在webview模式中,小米魅族手机不支持html5原生video的control的解决办法![原创]

    其实,解决办法就是,重新写个control控制功能,.同样用流行的video.js可以实现 第一步就是增加个播放的图片..要不然没有按钮多难看! <div class="videoDi ...

  4. python爬虫学习(一)

    #简单例子:抓取网页全部内容后,根据正则表达式,获取符合条件的字符串列表from urllib import request#正则表达式import re url = "http://www ...

  5. java基础--提示对话框的使用

    java基础--提示对话框的使用 2019-03-17-00:35:50-----云林原创 一.显示信息对话框:使用“JOptionPane.showMessageDialog”显示:   图标 对话 ...

  6. unity3D使用C#遍历场景内所有元素进行操作

    最近入门Unity3D,跟着教程做完了survival射击游戏,就想加一个功能,就是按一个按钮屏幕上的怪物都清空. 如图右下角所示. 我的方法是赋予所有怪物一个标签Tag,然后根据标签销毁Gameob ...

  7. fegin client使用http url合约时报: [Request processing failed; nested exception is feign.FeignException: status 400 reading

    首先看feign client代码: @FeignClient(name = "SPRING-CLOUD-WEB-PROVIDER-GROUP2", url = "htt ...

  8. sort属性

    学习文章---链接 总结笔记 ①sort是Array.prototype的属性, ②如果不写入参数,则按照转换为的字符串的每个字符的unicode位点进行排序, ③如果传入一个比较函数sort(fun ...

  9. Android 软键盘弹出,界面整体上移

    在做搜索功能的时候,点击搜索框,搜索框获取焦点,键盘弹出:现在问题出来了,android软键盘弹出的时候,android整个界面上移,布局被挤压,很难看:要解决这个问题,我们需要用到 windowSo ...

  10. iBrand 开源电商小程序 (Laravel API+ webpack + gulp + 原生小程序)

    iBrand 社交电商产品正式进入开源过程中了,我们制定了详细的开源计划,目前已经发布了 V1 的版本,后续的版本也在陆续整理完善中. 各个版本功能明细如下图: 3 个版本计划在今年春节前全部完成,可 ...