iOS中UILabel實(shí)現(xiàn)長(zhǎng)按復(fù)制功能實(shí)例代碼
前言
網(wǎng)上有很多種給Label添加長(zhǎng)按復(fù)制功能的方法,而在 UILabel 上實(shí)現(xiàn)長(zhǎng)按復(fù)制,我用的是 UIMenuController。在 UITextView、UITextField 中,已經(jīng)自帶了這個(gè)東西,但是在 UILabel 上需要自定義。
鑒于有的朋友很少接觸 UIMenuController,這里先介紹一些基本知識(shí)。
UIMenuController 可以使用系統(tǒng)自帶的方法,也可以自定義。
系統(tǒng)默認(rèn)支持UITextField、UITextView、UIWebView控件的UIMenuController相關(guān)操作
更多UIMenuController使用請(qǐng)參考這篇文章:http://www.dhdzp.com/article/87000.htm
常見(jiàn)的系統(tǒng)方法和使用
- (void)cut:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)copy:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)paste:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)select:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)selectAll:(nullable id)sender NS_AVAILABLE_IOS(3_0); - (void)delete:(nullable id)sender NS_AVAILABLE_IOS(3_2);
從字面意思就能看出,他們是剪切、復(fù)制、粘貼、選擇、全選、刪除。使用方法很簡(jiǎn)單。
// 比如我在一個(gè) UITextView 里,想增加全選和復(fù)制的方法
// 只要在自定義 UITextView 的時(shí)候加入這行代碼即可
- (BOOL)canPerformAction:(SEL)action withSender:(id)sender {
if(action == @selector(selectAll:) || action == @selector(copy:)) return YES;
return NO;
}
細(xì)心的朋友可能會(huì)發(fā)現(xiàn),最后長(zhǎng)按出來(lái)的文字都是英文,我們改如何把他改成中文呢?如圖,在 Project -> Info -> Localizations 中添加 Chinese(Simplified) 即可。

自定義方法和使用
回到主題,我們要在 UILabel 上加入長(zhǎng)按復(fù)制事件,但是他本身是不支持 UIMenuController 的,所以接下來(lái)講講自定義方法。
自定義一個(gè) UILabel,設(shè)置label可以成為第一響應(yīng)者
- (BOOL)canBecomeFirstResponder {
return YES;
}
設(shè)置長(zhǎng)按事件,在初始化的時(shí)候調(diào)用這個(gè)方法
- (void)setUp {
/* 你可以在這里添加一些代碼,比如字體、居中、夜間模式等 */
self.userInteractionEnabled = YES;
[self addGestureRecognizer:[[UILongPressGestureRecognizer alloc]initWithTarget:self action:@selector(longPress)]];
}
長(zhǎng)按事件,在里面新建 UIMenuController
- (void)longPress {
// 設(shè)置label為第一響應(yīng)者
[self becomeFirstResponder];
// 自定義 UIMenuController
UIMenuController * menu = [UIMenuController sharedMenuController];
UIMenuItem * item1 = [[UIMenuItem alloc]initWithTitle:@"復(fù)制" action:@selector(copyText:)];
menu.menuItems = @[item1];
[menu setTargetRect:self.bounds inView:self];
[menu setMenuVisible:YES animated:YES];
}
設(shè)置label能夠執(zhí)行那些
- (BOOL)canPerformAction:(SEL)action withSender:(id)sender {
if(action == @selector(copyText:)) return YES;
return NO;
}
// 如果模仿上面的寫(xiě)以下代碼,點(diǎn)擊后會(huì)導(dǎo)致程序崩潰
if(action == @selector(selectAll:) || action == @selector(copy:)) return YES;
方法的具體實(shí)現(xiàn)
- (void)copyText:(UIMenuController *)menu {
// 沒(méi)有文字時(shí)結(jié)束方法
if (!self.text) return;
// 復(fù)制文字到剪切板
UIPasteboard * paste = [UIPasteboard generalPasteboard];
paste.string = self.text;
}
最終效果:

附上 DEMO (本地下載),自定義的 UILabel 可以直接拖走使用
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- iOS基于 UILabel實(shí)現(xiàn)文字添加描邊功能
- iOS如何封裝帶復(fù)制功能的UILabel示例代碼
- iOS開(kāi)發(fā)總結(jié)之UILabel常用屬性介紹
- iOS中UILabel設(shè)置居上對(duì)齊、居中對(duì)齊、居下對(duì)齊及文字置頂顯示
- iOS動(dòng)態(tài)調(diào)整UILabel高度的幾種方法
- iOS UILabel 設(shè)置內(nèi)容的間距及高度的計(jì)算示例
- IOS 開(kāi)發(fā)之UILabel 或者 UIButton加下劃線鏈接
- iOS UILabel根據(jù)內(nèi)容自動(dòng)調(diào)整高度
- iOS兩丫技術(shù)之UILabel性能不夠的解決方法
相關(guān)文章
iOS實(shí)現(xiàn)scrollview上拉顯示Navbar下拉隱藏功能詳解
這篇文章主要給大家介紹了利用iOS實(shí)現(xiàn)scrollview上拉顯示Navbar下拉隱藏功能的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-05-05
iOS應(yīng)用開(kāi)發(fā)中運(yùn)用設(shè)計(jì)模式中的組合模式的實(shí)例解析
這篇文章主要介紹了iOS應(yīng)用開(kāi)發(fā)中運(yùn)用設(shè)計(jì)模式中的組合模式的實(shí)例解析,示例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-03-03
iOS 9 Core Spotlight搜索實(shí)例代碼
本文主要講解 iOS 9 Core Spotlight,在 IOS 開(kāi)發(fā)的時(shí)候有時(shí)候會(huì)用到搜索功能,這里給大家一個(gè)實(shí)例作為參考,有需要的小伙伴可以參考下2016-07-07
IOS 中l(wèi)oadView,viewDidLoad,viewDidUnload詳解及使用
這篇文章主要介紹了IOS 中l(wèi)oadView,viewDidLoad,viewDidUnload詳解及使用的相關(guān)資料,需要的朋友可以參考下2017-02-02
iOS10 適配-Xcode8問(wèn)題總結(jié)及解決方案
這篇文章主要介紹了iOS10 適配-Xcode8問(wèn)題總結(jié)的相關(guān)資料,這里整理了遇到的幾種問(wèn)題,并給出解決方案,需要的朋友可以參考下2016-11-11
iOS 通過(guò)collectionView實(shí)現(xiàn)照片刪除功能
這篇文章主要介紹了iOS 通過(guò)collectionView實(shí)現(xiàn)照片刪除功能,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-11-11

