let textfield = UITextField(frame: CGRectMake(10.0,10.0,200.0,40.0))
self.view.addSubview(textfield)
// 字体属性设置
textfield.textColor = UIColor.blackColor()
textfield.font = UIFont(name: "GillSans",size: 15.0)
textfield.textAlignment = NSTextAlignment.Left
textfield.placeholder = "textfield的使用"
textfield.secureTextEntry = false
<pre name="code" class="objc">// 光标颜色
textfield.textColor = UIColor.greenColor()
 
textfield.enabled = true
textfield.userInteractionEnabled = true
// 样式背景属性
textfield.backgroundColor = UIColor.lightGrayColor()
textfield.borderStyle = UITextBorderStyle.Line
// let image = UIImage(named: "normalImage")
// textfield.background = image
// 图标
let leftview = UIImageView(image: UIImage(named: "normalImage"))
leftview.frame = CGRectMake(0.0,0.0,30.0,30.0)
textfield.leftviewmode = UITextFieldviewmode.Always
textfield.leftView = leftview
let rightview = UIImageView(image: UIImage(named: "hightimage"))
rightview.frame = CGRectMake(0.0,30.0)
textfield.rightviewmode = UITextFieldviewmode.Always
textfield.rightView = rightview
// 代理,注意添加代理协议,及实现代理方法
textfield.delegate = self
// 添加协议
class ViewController: UIViewController,UITextFieldDelegate {

    override func viewDidLoad() {
 
   }
}
// 代理方法
// MARK: - UITextFieldDelegate
func textFieldShouldBeginEditing(textField: UITextField) -> Bool {
        
        print("1 textFieldShouldBeginEditing")
        
        return true
}
    
func textFieldDidBeginEditing(textField: UITextField) {
        print("2 textFieldDidBeginEditing")
}
    
func textField(textField: UITextField,shouldChangeCharactersInRange range: NSRange,replacementString string: String) -> Bool {
        print("3 textField")
        
        return true
}

func textFieldShouldEndEditing(textField: UITextField) -> Bool {
        print("4 textFieldShouldEndEditing")
        print("text:\(textField.text) length = \(textField.text?.characters.count)")
        return true
}
    
func textFieldDidEndEditing(textField: UITextField) {
        print("5 textFieldDidEndEditing")
}
    
func textFieldShouldClear(textField: UITextField) -> Bool {
        
        print("6 textFieldShouldClear")
        
        return true
}
    
func textFieldShouldReturn(textField: UITextField) -> Bool {
        
        // 结束编辑
        textField.resignFirstResponder()
        
        print("7 textFieldShouldReturn")
        
        return true
}
// 编辑属性设置
textfield.clearButtonMode = UITextFieldviewmode.WhileEditing
// 输入设置
textfield.keyboardType = UIKeyboardType.WebSearch
textfield.returnKeyType = UIReturnKeyType.Done
        
// 自定义输入源控件
// let inputview = UIButton(frame: CGRectMake(0.0,CGRectGetWidth(self.view.bounds),100.0))
// inputview.setimage(UIImage(named: "normalImage"),forState: UIControlState.normal)
// inputview.backgroundColor = UIColor.lightGrayColor()
// inputview.addTarget(self,action: Selector("click:"),forControlEvents: UIControlEvents.TouchUpInside)
// textfield.inputView = inputview
// 自定义输入源控件副视图
let accessoryview = UIView(frame: CGRectMake(0.0,40.0))
accessoryview.backgroundColor = UIColor.greenColor()
let accessoryLeft = UIButton(frame: CGRectMake(10.0,60.0,20.0))
accessoryview.addSubview(accessoryLeft)
accessoryLeft.setTitle("取消",forState: UIControlState.normal)
accessoryLeft.backgroundColor = UIColor.orangeColor()
accessoryLeft.addTarget(self,action: Selector("leftClick:"),forControlEvents: UIControlEvents.TouchUpInside)
let accessoryRight = UIButton(frame: CGRectMake((CGRectGetWidth(accessoryview.bounds) - 10.0 - 60.0),20.0))
accessoryview.addSubview(accessoryRight)
accessoryRight.setTitle("确定",forState: UIControlState.normal)
accessoryRight.backgroundColor = UIColor.orangeColor()
accessoryRight.addTarget(self,action: Selector("rightClick:"),forControlEvents: UIControlEvents.TouchUpInside)
textfield.inputAccessoryView = accessoryview
// 自定义输入源控件时响应事件
// MARK: - click
func click(button:UIButton)
{
        self.view.endEditing(true)
}
    
//MARK: - left/right click
func leftClick(button:UIButton)
{
        print("取消")
}
    
func rightClick(button:UIButton)
{
        self.view.endEditing(true)
        print("确定")
}
// 其他
// 第一响应,即进入编辑状态
// textfield.becomeFirstResponder()
// 结束响应,即结束编辑
// textfield.resignFirstResponder()
// 发通知-输入改变
NSNotificationCenter.defaultCenter().addobserver(self,selector: Selector("textFiledEditChanged:"),name: UITextFieldTextDidChangeNotification,object: textfield)
// 通知响应方法-限制输入长度
// MARK: - 通知响应方法
func textFiledEditChanged(notification:NSNotification)
{
        let textField:UITextField! = notification.object as! UITextField
        if (textField != nil)
        {
            let text:String! = textField.text
            let length = text.characters.count
            if (length > 20)
            {
                textField.text = text.substringToIndex(text.startIndex.advancedBy(20))
            }
        }
}


注意:不能同时设置clearButtonModerightviewmode/rightView属性,否则只有rightviewmode/rightView有效。


swift中UITextField的使用的更多相关文章

  1. ios – 如何通过编程方式为UIButtons组设置单个背景图像

    解决方法要使用选择器数组以编程方式创建按钮,您可以使用以下代码片段://定义策略

  2. ios – UIButton背景图像以编程方式更改

    如何在点击事件中更改我的UIButton的背景图像?并使用上一张图片在几秒钟内刷新它?我的意思是在点击后更改它的背景图像并在点击后重置它.解决方法将您的clickEvent图像作为按钮的突出显示图像.

  3. ios – UIPopoverController出现在错误的位置

    所以我花了一些时间寻找答案,但到目前为止还没有找到任何答案.我正在尝试从UIInputAccessoryView上的按钮呈现弹出窗口.UIBarButtonItem我想显示popover来自定制视图,所以我可以使用图像.我创建这样的按钮:当需要显示popover时,我这样做:但我得到的是:弹出窗口看起来很好,但它应该出现在第一个按钮上时出现在第二个按钮上.然后我发现了这个问题:UIBarButto

  4. ios – UITextField中的Autolayout:执行-layoutSubviews后仍需要自动布局

    我究竟做错了什么?

  5. ios – 无法在UIButton上更改自定义UIFont大小

    我有一个按钮,我使用自定义UIFont来显示文本.字体正确加载并正确应用于按钮标题.我的问题是我似乎无法改变字体大小:无论我输入什么字体大小,我都会得到一些默认大小.另一方面,如果我做这样的事情:我得到大小32字体,但是,当然,我没有得到我的自定义字体.那么,如何设置自定义字体的大小?解决方法要获取必须传递fontWithName:size:的字体名称,请使用FontBook应用程序打开字体,然后查找PostScript名称属性.确保您已将其添加到Info.plist文件中.

  6. ios – 如何使UITextField可选但不可编辑?

    我希望用户可以复制和粘贴文本,但不能编辑它们.我使用委托UITextField方法来实现这个:这样虽然文本是可选择的而且不可编辑,但是当你选择文本时,键盘总是显示出来,这有点烦人,因为你无法编辑文本.那么无论如何在不显示键盘的情况下使文本可选而不可编辑?,您可能需要添加:

  7. ios – 创建UIButton(UIButtonTypeCustom),顶部带有图像,底部带有AutoLayout标签

    我试图在它的底部显示带有文本的按钮.顶部的图像;图像&单击时必须突出显示文本.像这样:这是viewDidLoad中的代码:问题是文本根本不显示.请参阅下面的链接图像.如何使用UIEdgeInset为文本腾出空间?我也试过创建一个UIButton类,但效果大致相同.解决方法请使用以下代码设置插图,希望这可以帮助..

  8. ios – Touch拖动输入如何工作?

    任何人都可以给我一个关于触摸拖动输入以从一个按钮拖动到另一个触发两个按钮事件的示例.它是如何工作的?例如,我想从Do到Fa拖动Do,Re,Mi,Fa的事件被触发.这是我的代码:哦,我已经看到,当我按住Simulator时,会触发方法btnDragOut.当我从Simulator拖出按钮时,会触发此按钮的方法.现在我希望当我拖出一个按钮时触发方法btnDragOut.有谁知道吗?

  9. ios – 设置TouchID“输入密码”后备以开始编辑UITextField

    我在我的应用程序中设置了touchID并正常工作.但是,我想更改“输入密码”的功能.创建我的身份验证时,我遵循以下教程:http://www.appcoda.com/touch-id-api-ios8/但是,他们使用alertView作为“输入密码”选项.我想解雇touchIDalertview并让我的passwordTextField成为第一个响应者.当然我试过了:但这会导致错误:这是我的身份验

  10. ios – 如何让UIButton成为一个圆圈?

    我一直试图让细胞中的UIButton成为一个完美的圆圈.不幸的是,圆形是基于背景图像而不是UIButton框架形成的.我创建圆圈的代码:输出如下:我该怎么做才能获得我想要的完美圆形按钮框架?解决方法尝试这样的事情如果需要创建一个视图圆,则必须将masksToBounds设置为true,不要设置clipsToBounds希望这会帮助你.

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部