Xcode 自定義代碼片段

1.定義

代碼片段(Code Snippets),能夠快速的完成經常使用的代碼,提升效率。例如輸入if回車出現的就是系統已經定義好的代碼片段。

2.復用

自定義的代碼片段是能直接拷貝的,即使換電腦后也能直接復用,儲存位置為:
/用戶/~/Library/Developer/Xcode/UserData/CodeSnippets

3.創建

選中代碼塊,按住option,拖動代碼塊到右側位置,彈出編輯框

編輯.jpeg

使用.jpeg

4.常用代碼塊整理

4.0 其他常用功能

Title: weakSelf
Completion Shortcut: weakSelf
__weak typeof(self) weakSelf = self;

Title: 一句移除所有子控件
Completion Shortcut: ** removeFormSuper**
[<#view#>.subviews makeObjectsPerformSelector:@selector(removeFromSuperview)];

Title: SharedInstance
Completion Shortcut: SharedInstance

+ (instancetype)sharedInstance
{
    static id _sharedInstance = nil;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        _sharedInstance = [[self alloc] init];
    });
    return _sharedInstance;
}

Title: 設置陰影
Completion Shortcut: setShadow

<#view#>.layer.shadowColor = [UIColor whiteColor].CGColor;
<#view#>.layer.shadowOpacity = 1.0f;
<#view#>.layer.shadowRadius = 5.f;
<#view#>.layer.shadowOffset = CGSizeMake(0,0);
4.1變量聲明

Title: Static NSString
Completion Shortcut: @staticString
static NSString* const <#name#> = <#value#>;

Title: Static NSInteger
Completion Shortcut: @staticInt
static NSInteger const <#name#> = <#value#>;

4.2 聲明

Title: @property - assign
Completion Shortcut: @assign
property (nonatomic, assign) <#type#> *<#name#>;

Title: @property - strong
Completion Shortcut: @strong
property (nonatomic, strong) <#type#> *<#name#>;

Title: @property - copy
Completion Shortcut: @copy
property (nonatomic, copy) <#type#> *<#name#>;

Title: @property - weak
Completion Shortcut: @weak
property (nonatomic, weak) <#type#> *<#name#>;

Title: @property - delegate
Completion Shortcut: @delegate
property (nonatomic,weak) id<<#protocol#>> <#delegate#>;

4.3 注釋

Title: 注釋-1行
Completion Shortcut: Mark1
#pragma mark - <#name#>

Title: 注釋-2行
Completion Shortcut: Mark2
#pragma mark
#pragma mark --

4.4.1 UI --- Label

Title: AttributedLabel
Completion Shortcut: attributedLabel

UILabel *attributedLabel =[[UILabel alloc] init];
attributedLabel.numberOfLines = 0;
attributedLabel.preferredMaxLayoutWidth = <#preferredMaxLayoutWidth#>;
attributedLabel.backgroundColor = [UIColor clearColor];
NSString *text = <#text#>;
NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init];
style.lineSpacing = <#lineSpacing#>;
NSDictionary *attr = @{
    NSFontAttributeName: [UIFont <#font#>],
    NSParagraphStyleAttributeName: style,
    NSForegroundColorAttributeName: [UIColor <#color#>]
};
attributedLabel.attributedText = [[NSAttributedString alloc] initWithString:text attributes:attr];
[<#view#> addSubview:attributedLabel];
4.4.2 UI --- TableView

Title: TableView-初始化
Completion Shortcut: getTableView

- (UITableView *)tableView {
    if (!_tableView) {
        
        _tableView = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, SCREEN_WIDTH, 100) style:UITableViewStylePlain];
        _tableView.delegate = self;
        _tableView.dataSource = self;
        _tableView.backgroundColor = [UIColor clearColor];
        _tableView.scrollEnabled = NO;
        
        _tableView.estimatedRowHeight = 80;
        _tableView.rowHeight = UITableViewAutomaticDimension;
        _tableView.estimatedSectionFooterHeight = 0;
        _tableView.estimatedSectionHeaderHeight = 0;
        
        _tableView.separatorStyle = UITableViewCellSeparatorStyleNone;
        [_tableView setSeparatorColor:[UIColor whiteColor]];
        [_tableView setSeparatorInset:UIEdgeInsetsMake(0, 0, 0, 0)];
    }
    return _tableView;
}

Title: TableView-數據源方法
Completion Shortcut: ** getTableViewMethod**

#pragma mark
#pragma mark -- TableView DataSource/Delegate

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
    return <#count#>;
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return <#count#>;
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    <#classCell#> *cell = [tableView dequeueReusableCellWithIdentifier:<#kReuseIdentifier#> forIndexPath:indexPath];
    return cell;
}

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    [tableView deselectRowAtIndexPath:indexPath animated:NO];
}

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    return <#rowHeight#>;
}

Title: TableViewCell-重寫
Completion Shortcut: getTableViewCell

+ (RTHomeCell *)getHomeCellWithTableView:(UITableView *)tableView ID:(NSString *)ID{
    
    RTHomeCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
    if (cell == nil) {
        cell = [[self alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:ID];
        
        cell.backgroundColor = [UIColor clearColor];
        FTView *selView = [FTView getViewWithFrame:cell.frame bgColor:UIColorFromRGB(0x5be4fd,0.2)];
        cell.selectedBackgroundView = selView;
    }
    return cell;
}

- (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier {
    
    if (self = [super initWithStyle:style reuseIdentifier:reuseIdentifier]) {
        [self setupUI];
    }
    return self;
}

- (void)setupUI {
    
}
4.4.3 UI - CollectionView

Title: CollectionView-初始化
Completion Shortcut: getCollectionView

- (void)collectionView {
    if(!_collectionView){
        // 1.初始化layout
        UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc]init];
        layout.scrollDirection = UICollectionViewScrollDirectionHorizontal;
        layout.itemSize = CGSizeMake(<#itemWidth#>, <#itemHeight#>);
        layout.minimumInteritemSpacing = <#間距#>;
        layout.minimumLineSpacing = <#行距#>;
        
        // 2.初始化collectionView
        _collectionView = [[UICollectionView alloc]initWithFrame:CGRectMake(<#x#>, <#y#>, <#w#>, <#h#>) collectionViewLayout:layout];
        _collectionView.backgroundColor = [UIColor clearColor];
        _collectionView.dataSource = self;
        _collectionView.delegate = self;
        _collectionView.showsHorizontalScrollIndicator = NO;
        _collectionView.contentInset = UIEdgeInsetsMake(0, 12, 0, 12);
        [<#view#> addSubview:_collectionView];
        
        // 3.注冊cell
        [_collectionView registerClass:[<#CellClass#> class] forCellWithReuseIdentifier:<#CellID#>];
    }
    return _collectionView;
}

Title: CollectionView-數據源方法
Completion Shortcut: getCollectionViewMethod

#pragma mark
#pragma mark -- CollectionView DataSource/Delegate

-(NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section {
    return <#count#>;
}

- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath {

    UICollectionViewCell* cell =  [collectionView dequeueReusableCellWithReuseIdentifier:<#CellID#> forIndexPath:indexPath];
   
    return cell;
}

- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath {
    
}

Title: CollectionView-停在固定位置
Completion Shortcut: getCollectionViewStopFixedposition


// Cell滾動到指定位置
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset {
    // topCollView 滑動時停在指定位置
    if (scrollView == _topCollView) {
        CGPoint originalTargetContentOffset = CGPointMake(targetContentOffset->x, targetContentOffset->y);
        CGPoint targetCenter = CGPointMake(originalTargetContentOffset.x + CGRectGetWidth(self.topCollView.bounds)/2, CGRectGetHeight(self.topCollView.bounds) / 2);
        NSIndexPath *indexPath = nil;
        NSInteger i = 0;
        while (indexPath == nil) {
            targetCenter = CGPointMake(originalTargetContentOffset.x + CGRectGetWidth(self.topCollView.bounds)/2 + 10*i, CGRectGetHeight(self.topCollView.bounds) / 2);
            indexPath = [self.topCollView indexPathForItemAtPoint:targetCenter];
            detailIndex = indexPath.item;
            i++;
        }
        //    self.selectedIndex = indexPath;
        //這里用attributes比用cell要好很多,因為cell可能因為不在屏幕范圍內導致cellForItemAtIndexPath返回nil
        UICollectionViewLayoutAttributes *attributes = [self.topCollView.collectionViewLayout layoutAttributesForItemAtIndexPath:indexPath];
        if (attributes) {
            *targetContentOffset = CGPointMake(attributes.center.x - CGRectGetWidth(self.topCollView.bounds)/2+30, originalTargetContentOffset.y);
        } else {
            //            NSLog(@"center is %@; indexPath is {%@, %@}; cell is %@",NSStringFromCGPoint(targetCenter), @(indexPath.section), @(indexPath.item), attributes);
        }
    }
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,488評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,034評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,327評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,554評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,337評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,883評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,975評論 3 439
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,114評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,625評論 1 332
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,555評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,737評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,244評論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,973評論 3 345
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,362評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,615評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,343評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,699評論 2 370

推薦閱讀更多精彩內容