iOS/iPhone Hide Input Keyboard and Validate Text Field (Password, Number, URL, E-Mail, Phone Number) |
iOS/iPhone Hide Input Keyboard and Validate Text Field (Password, Number, URL, E-Mail, Phone Number) ในการเขียน iOS เพื่อรับค่า Input ต่าง ๆ เช่น Text Fields หรือ Textbox เราสามารถที่จะ Validate Keyboard ได้ เช่น ถ้าเป็นตัวเลข Number ก็ให้แสดงเฉพาะตัวเลข หรือประเภท หมายเลขโทรศัพท์ (Phone No) , URL เว็บไซต์ ทั้งนี้เพื่อความสะดวกแก้ผู้ใช้ที่จะทำการ Input ข้อมูล รวมทั้งจะได้ทำการตรวจสอบ Validate ข้อมูลเบื้องต้นอีกด้วย
iOS/iPhone Hide Input Keyboard and Validate Text Field (Password, Number, URL, E-Mail, Phone Number)
ในตัวอย่างนี้จะสอนวิธีการ Validate Text Field หรือ TextBox แบบง่าย ๆ โดยใช้ความสามารถของ Object Text Fields เอง และก็จะมีตัวอย่างการซ่อน Hide Input Keyboard เมื่อคลิกที่ตำแหน่งอื่น ๆ ของ View
iOS Hide Input Keyboard
[txtName resignFirstResponder];
Example 1 การ Validate Text Field กับ Input Keyboard และการซ้อน Hide Input Keyboard
data:image/s3,"s3://crabby-images/c2d65/c2d65e5f69ba038906f12ae240ed9b13e565a535" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
เริ่มต้นด้วยการสร้าง Application บน Xcode ง่าย ๆ แบบ Single View Application
data:image/s3,"s3://crabby-images/9f9b9/9f9b95e7dd73c38a71a4276c1ded044b2e675481" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
เลือกและไม่เลือกดังรูป
data:image/s3,"s3://crabby-images/20598/2059809fa6e3a4cbcf143aeb4910464e6ef5ab80" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
ตอนนี้หน้าจอ View จะยังว่าง ๆ ดังรูป
data:image/s3,"s3://crabby-images/6be37/6be377a9fffa6375c5789a446b98575b567e4c1e" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
ออกแบบหน้าจอ View ง่าย ๆ ดังรูป
data:image/s3,"s3://crabby-images/0f63f/0f63fbe5fee921142241c596ba4b1b2fe8a4e193" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
กรณีที่เป็น Text Fields แบบรหัสผ่าน (Password) ให้เลือก Secure
data:image/s3,"s3://crabby-images/87f6d/87f6d225b1b3f46c0988e1a6630734c48c7414cf" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
ในการที่จะ Validate Input Keyboard ให้กำหนดคุณสมบัติของแต่ล่ะ Text Field ได้ทันที โดยคลิกที่ Keyboard
data:image/s3,"s3://crabby-images/c0189/c01897a66e8d68a8fd6b2196157ad0f92f0b4f10" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
เลือกรูปแบบต่าง ๆ ตามต้องการ เช่น Number , Phone , URL , E-Mail หรืออื่น ๆ ขึ้นอยู่กับชนิดข้อมูลที่ต้องการ
Screenshot
data:image/s3,"s3://crabby-images/3bc74/3bc749803293028736484bfc8cac07f11751ae1b" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
แบบ Password ที่เป็น Secure
data:image/s3,"s3://crabby-images/3f5d2/3f5d2996b2ffcff602fd2962c999ddfebba9de9f" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
แบบ Number
data:image/s3,"s3://crabby-images/822ad/822ad0a11ba2350b27b8caa1e03bc5841ac35cd4" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
แบบ URL
data:image/s3,"s3://crabby-images/46c4d/46c4d5e12f6810255dd64bd6f64ed6303bfab81f" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
แบบ E-Mail
data:image/s3,"s3://crabby-images/c3f1f/c3f1fcf1894234929c007703a777056ab22634cd" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
แบบ Phone No
Example 2 การซ่อนหรือ Hide Input Keyboard หลังจากที่ได้คลิกในตำแหน่งอื่น ๆ ของ View
data:image/s3,"s3://crabby-images/a25ab/a25ab208ebd4b16ae1a075ecbf383223c8750532" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
ใน Class ของ.h ให้เชื่อม IBOutlet ดังรูป
data:image/s3,"s3://crabby-images/07f15/07f158ef7865ded9fcfb40e332f309fda8e0e657" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
ในการที่เราจะคลิกตำแหน่งอื่น ๆ ของ View แล้วเขียน Handle นั้นเราจะต้องอาศัย Gesture เข้ามาช่วย โดยใช้ Gesture ที่มีชื่อว่า UITapGestureRecognizer
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
// Tap Gesture for Hide Keyboard
UITapGestureRecognizer *oneTapGesture = [[UITapGestureRecognizer alloc]
initWithTarget: self
action: @selector(hideKeyboard:)];
[oneTapGesture setNumberOfTouchesRequired:1];
[[self view] addGestureRecognizer:oneTapGesture];
}
// Event Gesture for Hide Keyboard
- (void)hideKeyboard:(UITapGestureRecognizer *)sender {
[txtPassword resignFirstResponder];
[txtNumber resignFirstResponder];
[txtURL resignFirstResponder];
[txtEmail resignFirstResponder];
[txtPhone resignFirstResponder];
}
Screenshot
data:image/s3,"s3://crabby-images/9f5fd/9f5fdd737072c2830af3e69943d603428c0fcf80" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
เมื่อคลิกที่ Text Fields หรือ TextBox จะแสดง Input Keyboard
data:image/s3,"s3://crabby-images/79062/790626c36270ac7f20153beb00b4940343f76b52" alt="iOS/iPhone Hide Input Keyboard and Validate Text Field iOS/iPhone Hide Input Keyboard and Validate Text Field"
เมื่อคลิกที่ตำแหน่งอื่น ๆ บน View ตัว Input Keyboard จะหายไป
Code ทั้งหมดของ .h และ .m ในภาษา Objective-C
ViewController.h
//
// ViewController.h
// inputTextFieldsKeyboard
//
// Created by Weerachai on 12/10/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import <UIKit/UIKit.h>
@interface ViewController : UIViewController
{
IBOutlet UITextField *txtPassword;
IBOutlet UITextField *txtNumber;
IBOutlet UITextField *txtURL;
IBOutlet UITextField *txtEmail;
IBOutlet UITextField *txtPhone;
}
@end
ViewController.m
//
// ViewController.m
// inputTextFieldsKeyboard
//
// Created by Weerachai on 12/10/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
// Tap Gesture for Hide Keyboard
UITapGestureRecognizer *oneTapGesture = [[UITapGestureRecognizer alloc]
initWithTarget: self
action: @selector(hideKeyboard:)];
[oneTapGesture setNumberOfTouchesRequired:1];
[[self view] addGestureRecognizer:oneTapGesture];
}
// Event Gesture for Hide Keyboard
- (void)hideKeyboard:(UITapGestureRecognizer *)sender {
[txtPassword resignFirstResponder];
[txtNumber resignFirstResponder];
[txtURL resignFirstResponder];
[txtEmail resignFirstResponder];
[txtPhone resignFirstResponder];
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (void)dealloc {
[txtPassword release];
[txtNumber release];
[txtURL release];
[txtEmail release];
[txtPhone release];
[super dealloc];
}
@end
|
ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท
|
|
|
By : |
ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ) |
|
Score Rating : |
data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" |
|
|
Create/Update Date : |
2012-12-12 08:50:14 /
2017-03-26 09:47:19 |
|
Download : |
|
|
Sponsored Links / Related |
|
|
|
|
|
|
|