UITextField、UILabel、UIButton的基本使用

import "AppDelegate.h"

@interface AppDelegate ()

@end

@implementation AppDelegate

  • (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
    // Override point for customization after application launch.
    self.window.backgroundColor = [UIColor whiteColor];
    [self.window makeKeyAndVisible];
    [self.window setRootViewController:[[UIViewController alloc]init]];

// textField(输入框)的使用
// 初始化并设置frame
UITextField *textField = [[UITextField alloc]initWithFrame:CGRectMake(100, 200, 200, 50)];
// 设置占位字符(提示性文字)
textField.placeholder = @"请输入手机号/邮箱";
// 设置边框样式
textField.borderStyle = UITextBorderStyleLine;
// [textField setBackgroundColor : [UIColor redColor]];
[self.window addSubview:textField];
// 给字体设置颜色
[textField setTextColor:[UIColor blackColor]];
// 改变字体大小
textField.font = [UIFont systemFontOfSize:15];
// 得到系统支持的所有字体名称
// NSLog(@"%@",[UIFont familyNames]);
// 设置字体样式、大小
textField.font = [UIFont fontWithName:@"Hiragino Sans" size:15];
// 设置键盘样式
[textField setKeyboardType:UIKeyboardTypeASCIICapable];
// 设置键盘的外观
[textField setKeyboardAppearance:UIKeyboardAppearanceDark];
// 自动纠错设置
[textField setAutocorrectionType:UITextAutocorrectionTypeYes];
// 设置首字母大写 (首字母不能大写时,有可能和键盘样式有关)
textField.autocapitalizationType = UITextAutocapitalizationTypeWords;
// 一键清除(右边的小叉号)
textField.clearButtonMode = UITextFieldViewModeUnlessEditing;
// 当变为编辑状态时,让该textfeild刚刚所有的输入清除
textField.clearsOnBeginEditing = YES;

UITextField *textField1 = [[UITextField alloc]initWithFrame:CGRectMake(100, 260, 200, 50)];
textField1.backgroundColor = [UIColor yellowColor];
[self.window addSubview:textField1];


//  打开密码格式(密码样式是否可自定义)
textField.secureTextEntry = YES;
//  设置背景图像(如果不是PNG格式的,必须加后缀名,因为没有后缀名的时候,系统默认是PNG格式的)
textField.background = [UIImage imageNamed:@"11.png"];
//  文字的居左,居右,居中
textField.textAlignment = NSTextAlignmentCenter;
//  设置文字的垂直位置
textField.contentVerticalAlignment = UIControlContentVerticalAlignmentTop ;
//  不让进行编辑(交互)
textField.enabled = NO; // enable:改变控件本身的状态,例如:textfield有可编辑状态和不可编辑状态。当设置为NO时,textfield就会从可编辑状态改变为不可编辑状态
textField.userInteractionEnabled = NO; //  userInteractionEnabled:不可改变控件的状态,只是把用户交互关闭了,就是用户不可对该控件进行操作。

// 添加辅助视图
UIView *accessoryView =[[UIView alloc]initWithFrame:CGRectMake(0, 0, CGRectGetWidth(self.window.frame), 50)];
accessoryView.backgroundColor = [UIColor blackColor];
textField.inputAccessoryView = accessoryView;

//  自定义输入视图(自定义键盘)
UIView *inputView1 = [[UIView alloc]initWithFrame:CGRectMake(0, 0, CGRectGetWidth(self.window.frame), 256)];
textField.inputView =inputView1;

//  左视图
UILabel *lable = [[UILabel alloc]initWithFrame:CGRectMake(0, 0, 60, 100)];
lable.backgroundColor = [UIColor redColor];
textField.leftView = lable;
lable.text = @"用户名";
textField.leftViewMode = UITextFieldViewModeAlways;

//  右视图
UILabel *lable1 = [[UILabel alloc]initWithFrame:CGRectMake(50, 0, 60, 100)];
lable1.backgroundColor = [UIColor greenColor];
lable1.text = @"@sina.com";
textField.rightView = lable1;
textField.rightViewMode = UITextFieldViewModeAlways;

// UIButton的使用
// 按钮的初始化
UIButton *button = [UIButton buttonWithType:UIButtonTypeDetailDisclosure];
button.frame = CGRectMake(150, 100, 100, 50);
button.backgroundColor = [UIColor blackColor];
// 设置按钮标题
// normal:是按钮常态,不做任何操作和设置情况下看到的按钮状态
// Highlighted: 用户按住按钮不松手时看到的状态
[button setTitle:@"BMW" forState:UIControlStateNormal];
[button setTitle:@"MJ" forState:UIControlStateHighlighted];
// 关闭交互的状态标题(前一次操作后执行需要的时间较长,暂时关闭交互状态)
// [button setTitle:@"JMN" forState:UIControlStateDisabled];
// button.enabled = NO;
// 按钮被选中状态
// [button setTitle:@"一直被选中" forState:UIControlStateSelected];
// 设置按钮被选中
// [button setSelected:YES];
[button setTitleColor:[UIColor greenColor] forState:UIControlStateNormal];
[button setTitleColor:[UIColor blueColor] forState:UIControlStateHighlighted];
// 当点击时有光圈效果
button.showsTouchWhenHighlighted = YES;

//  给按钮添加点击事件(目标动作机制)
//  target:回调方法的执行者
//  action:按钮的回调方法(点击所触发的事件),如果回调方法带参数,这个参数只能是按钮本身
//  controlEvents:触发事件的点击模式

[button addTarget:self action:@selector(buttonAction:) forControlEvents:
 UIControlEventTouchUpInside];

/*
UIControlEventTouchDown  点击后触发事件
UIControlEventTouchDownRepeat  双击后触发事件
UIControlEventTouchDragInside  区域内拖拽触发事件
UIControlEventTouchDragOutside  区域内拖拽至区域外,拖动过程中不要松手触发事件
UIControlEventTouchDragEnter  从区域内拖拽出,不松手,在拖拽进去触发事件
UIControlEventTouchDragExit  拖拽出去、进来、再出去时触发事件
UIControlEventTouchUpInside  点击后触发事件(最常用)
UIControlEventTouchUpOutside
UIControlEventTouchCancel  多点触控时触发事件
*/

//  关闭多点触控
button.multipleTouchEnabled = NO;

textField.tag = 1000; // 给textField添加tag值,tag的作用是,为当前view或者其子类添加标记,当前view或者其子类的父视图可以通过tag找到该视图。

[self.window addSubview:button];
return YES;

}

// button的点击事件实现部分
-(void)buttonAction:(id)sender{
UIButton button = (UIButton)sender;
[button setTitle:@"hello world" forState:UIControlStateNormal];
self.window.backgroundColor = [UIColor colorWithRed:arc4random()%256/255.0 green:arc4random()%256/255.0 blue:arc4random()%256/255.0 alpha:1.0];
NSLog(@"@@@@@");

//  点击按钮可以得到文本输入框中的文字
//  textField不能是全局变量或者属性

//  父视图通过tag值得到field

UITextField *tagTextField = (UITextField *)[self.window viewWithTag:1000];
//  得到文本框输入的内容
NSString *textFieldStr = tagTextField.placeholder;
NSLog(@"%@",textFieldStr);

}

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

推荐阅读更多精彩内容