一、引言
iOS9中為我們提供了許多新的api夕晓,搜索功能的加強(qiáng)無疑是其中比較顯眼的一個(gè)。首先悠咱,我們先設(shè)想一下:如果在你的app中定義一種標(biāo)識符蒸辆,在siri和搜索中,可以用過這個(gè)標(biāo)識符搜索到你的app析既,是不是很棒躬贡?不,這還差得遠(yuǎn)眼坏,你可以定義任意的數(shù)據(jù)拂玻,使其在搜索和siri
中可以快速檢索到,這 樣的搜索功能是不是非常酷纺讲?不擂仍,還有更c(diǎn)ool的,你甚至可以在你的網(wǎng)站中添加一些標(biāo)志熬甚,使apple的爬蟲可以檢索到逢渔,那樣,即使用戶沒有安裝你的app乡括,也可以在搜索中獲取到相應(yīng)的信息肃廓,這太強(qiáng)大了,對吧诲泌。
二盲赊、3種全新的搜索模式
1.NSUserActivity
我們可以在項(xiàng)目中使用相應(yīng)的函數(shù)來添加一些用戶的活躍元素,使我們可以在搜索中通過搜索這樣的活躍元素展現(xiàn)我們的app敷扫。例如:
//創(chuàng)建一個(gè)對象哀蘑,這里的type用于區(qū)分搜索的類型
NSUserActivity *userActivity = [[NSUserActivity alloc] initWithActivityType: @"myapp"];
//顯示的標(biāo)題
userActivity.title = @"我的app";
// 搜索的關(guān)鍵字
userActivity.keywords = [NSSet setWithArray: @[@"sea",@"rch"]];
// 支持Search
userActivity.eligibleForSearch = YES;
//提交設(shè)置
[userActivity becomeCurrent];
在下面的函數(shù)中,我們可以處理用戶點(diǎn)擊搜索后的回調(diào):
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler: {
NSString *activityType = userActivity.activityType;
if ([activityType isEqual: @"myapp"]){
// Handle restoration for values provided in userInfo
// do something
return YES;
}
return NO;
//處理回調(diào)
}
TIP:這種方式添加的關(guān)鍵字搜索葵第,必須創(chuàng)建全局變量绘迁,否則無法進(jìn)行搜索:
2.CoreSpotlight
CoreSpotlight
是一種更加自由的搜索方式,可以通過添加類似item
的模型卒密,將app中的數(shù)據(jù)展示在搜索欄中缀台,CoreSpotlight
框架類似提供了一些增、刪哮奇、改膛腐、查的操作,可是使我們自由的進(jìn)行搜索屬性的設(shè)置鼎俘。
(1) 認(rèn)識3個(gè)類
在iOS9中哲身,新增加了3個(gè)類,通過對這三個(gè)類的操作與配合而芥,我們可以輕易的在app中添加CoreSpotlight
搜索的功能律罢。
CSSearchableItemAttributeSet
:設(shè)置類,這個(gè)類用于設(shè)置搜索標(biāo)簽里的icon棍丐,內(nèi)容误辑,圖片等。主要用法如下:
//這個(gè)類的核心方法只有一個(gè)`init`方法歌逢,通過一個(gè)類型字符串進(jìn)行創(chuàng)建巾钉,字符串用于在回調(diào)中區(qū)分
@interface CSSearchableItemAttributeSet : NSObject <NSCopying,NSSecureCoding>
- (instancetype)initWithItemContentType:(nonnull NSString *)itemContentType;
@end
//更多的屬性設(shè)置在其擴(kuò)展類中,例如:
@interface CSSearchableItemAttributeSet (CSGeneral)
//展示的名稱
@property(nullable, copy) NSString *displayName;
//名稱數(shù)組
@property(nullable, copy) NSArray<NSString*> *alternateNames;
//完整的路徑
@property(nullable, copy) NSString *path;
//鏈接url
@property(nullable, strong) NSURL *contentURL;
//圖片鏈接的url
@property(nullable, strong) NSURL *thumbnailURL;
//設(shè)置圖片數(shù)據(jù)
@property(nullable, copy) NSData *thumbnailData;
//設(shè)置一個(gè)標(biāo)識符
@property(nullable, copy) NSString *relatedUniqueIdentifier;
@property(nullable, strong) NSDate *metadataModificationDate;
//內(nèi)容類型
@property(nullable, copy) NSString *contentType;
@property(nullable, copy) NSArray<NSString*> *contentTypeTree;
//搜索的關(guān)鍵字?jǐn)?shù)組
@property(nullable, copy) NSArray<NSString*> *keywords;
//標(biāo)題信息
@property(nullable, copy) NSString *title;
@end
CSSearchableItem
:搜索標(biāo)簽類秘案,通過這個(gè)類砰苍,來創(chuàng)建響應(yīng)的搜索標(biāo)簽潦匈。主要內(nèi)容如下:
//這個(gè)類主要用于創(chuàng)建搜索的標(biāo)簽
@interface CSSearchableItem : NSObject <NSSecureCoding, NSCopying>
//init方法
- (instancetype)initWithUniqueIdentifier:(nullable NSString *)uniqueIdentifier //Can be null, one will be generated
domainIdentifier:(nullable NSString *)domainIdentifier
attributeSet:(CSSearchableItemAttributeSet *)attributeSet;
//相應(yīng) 的屬性
@property (copy) NSString *uniqueIdentifier;
@property (copy, nullable) NSString *domainIdentifier;
@property (copy, null_resettable) NSDate * expirationDate;
@property (strong) CSSearchableItemAttributeSet *attributeSet;
@end
CSSearchableIndex
:這個(gè)類,我個(gè)人理解赚导,類似一個(gè)manager
的作用茬缩,通過它對標(biāo)簽進(jìn)行增、刪吼旧、改凰锡、查等操作:
@interface CSSearchableIndex : NSObject
@property (weak,nullable) id<CSSearchableIndexDelegate> indexDelegate;
//判斷設(shè)備是否支持
+ (BOOL)isIndexingAvailable;
//取系統(tǒng)的searchIndex管理者
+ (instancetype)defaultSearchableIndex;
//一般情況下,我們不需要重新創(chuàng)建對象
- (instancetype)initWithName:(NSString *)name;
- (instancetype)initWithName:(NSString *)name protectionClass:(nullable NSString *)protectionClass;
//設(shè)置索引標(biāo)簽
- (void)indexSearchableItems:(NSArray<CSSearchableItem *> *)items completionHandler:(void (^ __nullable)(NSError * __nullable error))completionHandler;
//刪除指定id索引標(biāo)簽
- (void)deleteSearchableItemsWithIdentifiers:(NSArray<NSString *> *)identifiers completionHandler:(void (^ __nullable)(NSError * __nullable error))completionHandler;
- (void)deleteSearchableItemsWithDomainIdentifiers:(NSArray<NSString *> *)domainIdentifiers completionHandler:(void (^ __nullable)(NSError * __nullable error))completionHandler;
//刪除所有索引標(biāo)簽
- (void)deleteAllSearchableItemsWithCompletionHandler:(void (^ __nullable)(NSError * __nullable error))completionHandler;
@end
(2) 一個(gè)小例子
下面圈暗,我們通過一個(gè)小例子來應(yīng)用下CoreSpotlight
的搜索功能掂为。
首先,需要在項(xiàng)目中導(dǎo)入如下庫:
實(shí)現(xiàn)代碼如下:
//進(jìn)行標(biāo)簽設(shè)置
CSSearchableItemAttributeSet * itemSet = [[CSSearchableItemAttributeSet alloc]initWithItemContentType:@"myApp"];
itemSet.title = @"我的APP";
itemSet.keywords = @[@"haha",@"123"];
itemSet.contentDescription = @"這是搜索到得內(nèi)容";
itemSet.thumbnailData = UIImagePNGRepresentation([UIImage imageNamed:@"Icon-114.png"]);
CSSearchableItem * item = [[CSSearchableItem alloc]initWithUniqueIdentifier:@"1" domainIdentifier:@"1" attributeSet:itemSet];
[[CSSearchableIndex defaultSearchableIndex]indexSearchableItems:@[item] completionHandler:nil];
我們在搜索中輸入haha或者123效果如下:
CoreSpotlight
的搜索回調(diào)和NSUserActivaty
一樣员串,只是區(qū)分id
的方式有所不同:(寫在APPDelegte
中)
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:
{
NSString *activityType = userActivity.activityType;
//先取CSSearchableItemActionType
if ([activityType isEqual: CSSearchableItemActionType]) {
NSString *uniqueIdentifier = [userActivity.userInfo objectForKey:CSSearchableItemActivityIdentifier];
// do something
return YES;
}
return NO;
}
3勇哗、Web Markup
這個(gè)功能與我們app開發(fā)關(guān)系不大拓轻,但是對我app的推廣卻至關(guān)重要绊困,這項(xiàng)技術(shù)可以讓我們的app關(guān)聯(lián)一個(gè)網(wǎng)站章姓,apple通過爬蟲來獲取我們規(guī)定的一些標(biāo)簽值墨林,無論用戶是否安裝了app,在搜索時(shí)甘苍,都可以展示出相關(guān)信息灯荧,因?yàn)檫@項(xiàng)功能主要關(guān)聯(lián)前端技術(shù)纹蝴,需要了解的可以參看:
App Search Programming Guide
三海铆、總結(jié)
iOS9的搜索功能固然強(qiáng)大,然而濫用會造成垃圾信息的泛濫挣惰,這樣的結(jié)果一定會適得其反卧斟,作為開發(fā)者,我們需要將最合適憎茂,最簡潔的信息推送到用戶的面前珍语。