frame是视图在屏幕中展示的位置和大小,也就是可视区域的位置和大小。 contentSize是scrollView视图的内部内容可以滚动的区域大小,也就是scrollView视图内容的实际大小。...contentOffset是scrollView实际滚动区域的左上角与视图可视区域左上角的距离。 pagingEnabled是是否以一页的大小整体进行滚动,也就是用来实现翻页的效果。...用于页面滚动停止的时候开启一个逻辑,比如视频自动播放(页面停止滚动后,开启视图滚动前暂停的gif或者视图的播放) - (void)scrollViewDidEndDecelerating:(UIScrollView...上图是我在知乎首页的一个截图。 首先,整个从上而下它是一个tableView+collectionView。...(内容列表是tableView,“关注、推荐、热榜”标题栏是一个collectionView) 然后,“关注、推荐、热榜”每一个标题栏都对应一个tableView,一共有3个tableView,这三个tableView
中的cell特性外,CollectionView中的Item大小和位置可以自由定义 4、通过layout布局回调的代理方法,可以动态的定制每个item的大小和collection的大体布局属性 5、更加强大一点...有些类似,又有些不同,因为tableView除了注册cell的方法外,还可以通过临时创建来做: //tableView在从复用池中取cell的时候,有如下两种方法 //使用这种方式如果复用池中无,是可以返回...,因此这里统一了从复用池中获取cell的方法,没有再提供可以返回nil的方式,并且在UICollectionView的回调代理中,只能使用从复用池中获取cell的方式进行cell的返回,其他方式会崩溃,...同样,如果内容的大小超出一屏,和tableView类似是可以进行视图滑动的。...则会在一列充满后,进行第二列的布局,这种方式也被称为流式布局 三、UICollectionView中的常用方法和属性 //通过一个布局策略初识化CollectionView - (instancetype
子 View 的顺序和子 View 返回的数组中的位置有关(storyboard 中左侧的树形结构图中的先后顺序)。...// 纯代码实现复用 // 去重用池子中找cell var cell = tableView.dequeueReusableCell(withIdentifier:...) { if editingStyle == .delete { // 1.删除数组中对应的数据 content?....直接在 storyboard 中布局,不需要使用数据源方法,但如果需要使用到代理方法,仍然需要在控制器中实现相应的方法。 适用于基本不需要动态修改、布局固定的页面,如个人中心、设置等。...如果是自定义布局,需要传入一个 NSCollectionLayoutGroupCustomItemProvider 来决定这个 Group 中 Item 的布局方式。
UITableView中的row,对应到UICollectionView中就是item,因为一行可以展示多个cell,使用row(行)不能准确地表达。...例如,UITableView中的如下代理方法: - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger...UICollectionViewFlowLayout的设计理念就是,item现在一行中依次排列,一行满了之后就换一行接着排列剩余的Item。...其有三个比较重要的属性:minimumInteritemSpacing设置一行中两个Item之间的最小间距,minimumLineSpacing设置上下两行之间的最小间距,itemSize设置每一个item...中的代理方法: @protocol UICollectionViewDelegateFlowLayout @optional - (CGSize)collectionView
TableView是iOS开发中经常用到的View,针对不同的显示需求,我们需要不同的Cell来进行显示,比较复杂的显示我们一般会自定义Cell的样式,但是简单的显示就可以靠iOS本身支持的列表类型了。...iOS目前支持四中列表类型,分别是: UITableViewCellStyleDefault:默认类型,可以显示图片和文本 UITableViewCellStyleSubtitle:可以显示图片、文本和子文本...要设置也很简单,代码如下: - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath...,支持显示图片和文本 { NSString *CellOne = @"CellOne"; // 设置tableview类型...UITableViewCellStyleValue2类型,支持显示文本以及子文本 { NSString *CellFour = @"CellFour"; // 设置tableview
} 2、修改UITextField的placeholderLabel的默认字体颜色 inputTextField.text = "123" //备注:因为苹果公司开发过程中使用的是懒加载,所以如果不提前进行设置储值...UICollection使用的是一个UICollectionReusableView来进行创建 collectionView.register(UICollectionReusableView, forSupplementaryViewOfKind...pageControl.currentPage = currentIndex } } } func scrollViewDidEndDecelerating...return dropListView }() view.addSubview(dropListView) 使用方法 运行效果: 提示:之所以为空白,是因为我把下拉列表中的...tableView.reloadData()这行代码屏蔽掉了,加入的数组没有刷新。
把当前的控制器作为一个父控制器,添加三个UITableViewController的实例作为子控制器,把父控制器中的 scrollView 作为容器,然后添加子控制器中的 tableView 作为子视图...pagingEnabled = true collectionView?.bounces = false 这样滑动的时候就会有翻页的段落感,滑到边界的时候也不会有回弹效果。...然后要用 layout 控制布局,用最常用的 UICollectionViewFlowLayout 就行了,设置单元格的宽高,既然是翻页,宽肯定是跟屏幕等宽,高度就看你需求了,但是不要超过 collectionView...因为这边只是个 Demo,所以我直接在 cell 中显示cellData的值,那cellData 的值在哪里设置呢?...这边 cell 是会被复用的,在翻到第三页时,会复用第一页的 cell ,第四页复用第二页的 cell……依此类推,所以需要给 cell 中的tableView调用 reloadData方法,不然就算改变了表中的数据
:@"ImageLabelTableViewCell" forIndexPath:indexPath]; 如果用的storybord中的tableview的cell直接用dequeueReusableCellWithIdentifier...方法就行了 注意dequeueReusableCellWithIdentifier方法是从已经实例化的cell中查找id为textLeftCell的对象并进行拷贝 实例化视图控制器 从storyboard...中 Swift self.storyboard?....MyCell; OC MyCell *cell = [self.collectionView dequeueReusableCellWithReuseIdentifier:@"MyCell" forIndexPath...:indexPath]; 从xib中实例化对象 let cell = NSBundle.mainBundle().loadNibNamed("FuImageLabelTableViewCell", owner
场景需求 一个表格视图(或者宫格视图)中,当一个单元格被选中时设置彩色样式,选中其它单元格时设置灰色样式。 2. 一个思路 通过实现选中和非选择的代理,以在适当的时机进行UI更新操作。 3....UITableView 3.1 通过屏幕点击改变的选中状态回调给代理 //选中 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath...UICollectionView 4.1 通过屏幕点击改变的选中状态回调给代理 //选中 - (void)collectionView:(UICollectionView *)collectionView...之后,通过屏幕点击选中其它cell的时候,可以执行- (void)collectionView:(UICollectionView *)collectionView didDeselectItemAtIndexPath...cell的时候,UITableView并不会执行- (void)collectionView:(UICollectionView *)collectionView didDeselectItemAtIndexPath
在直播卖货小程序源码中,一般都包含商品分类页面,如下图,那么这个页面是如何通过代码实现的呢?下面,小编以iOS版本的开发过程为例,来讲述下实现过程。...图片1.png 左边一级分类使用tableview来展示,右边的耳机分类使用collectionview来展示,主要就是实现一二级分类的联动。下面主要讲下点击和滑动。...1、左侧一级分类的点击实现 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath...的代理方法中更改一级分类的选中 ///collectionview将要加载头尾视图调用的方法 - (void)collectionView:(UICollectionView *)collectionView...已经加载完头尾视图调用的方法 - (void)collectionView:(UICollectionView *)collectionView didEndDisplayingSupplementaryView
大家好,又见面了,我是你们的朋友全栈君。...项目中使用了UITableViewController,里面有用到UITextView需要点击键盘外的地方来隐藏我的键盘 自定义一个uitableview,继承UITableView。
iOS中,UICollectionView和UITableView已经有系统默认选中颜色设置,但是只有无色,蓝色,灰色,三种颜色设置,如果想要其他的颜色效果,我们可以自由自定义设置。...前言 先观赏一下典型的UITableView控件案例 ? image.png 典型的UICollectionView控件案例 ?...cell的代理方法中作如下设置: cell.selectedBackgroundView = [[UIView alloc] initWithFrame:cell.frame]; cell.selectedBackgroundView.backgroundColor...文件中重写如下方法: 示例: UITableViewCell.m - (void)setHighlighted:(BOOL)highlighted animated:(BOOL)animated{...注意的是,方案一和方案二不要重复设置。另外,二者择一的话,推荐方案一。
在Demo中对所需的组件进行的简单封装,在封装的组件中使用的是纯代码的形式,如果想要在项目中进行使用,稍微进行修改即可。 ...主要的技术点就是通过ScrollView的回调,通过事件的响应来改变ScrollView的ContentOffset的值。在回调中根据ContentOffset的值来计算红色指示器的偏移量。 ...二:核心代码 1.组件中的主要属性 把上面整个视图进行了封装,命名为SlideTabBarView,下面的代码是主要属性: 1 @interface SlideTabBarView()<UIScrollViewDelegate...下面最后一个代理方法是根据ScrollView的偏移量来计算红色指示器的偏移量,第二个是滑动到哪个tableView,然后进行哪个TableView的数据加载。...{ 3 [self scrollViewDidEndDecelerating:scrollView]; 4 } 5 6 - (void)scrollViewDidEndDecelerating
TableView用法差不多,功能应该也是类似的。...TableView的功能就已经很强大了,,CollectionView就是TableView的升级版,其功能更为强大。...以后的几篇博客中好好的研究一下CollectionView,由浅入深,层层深入,搞透CollectionView这个强大的组件。...3.在代码中实现相应的代理,和TableView非常类似 (1) 返回Section个数的方法 Objective-C - (NSInteger)numberOfSectionsInCollectionView...:(UICollectionView *)collectionView { return 1; } (2) 返回每个Section中Cell个数的方法 Objective-C - (NSInteger
TableView用法差不多,功能应该也是类似的。...TableView的功能就已经很强大了,,CollectionView就是TableView的升级版,其功能更为强大。...以后的几篇博客中好好的研究一下CollectionView,由浅入深,层层深入,搞透CollectionView这个强大的组件。...3.在代码中实现相应的代理,和TableView非常类似 (1) 返回Section个数的方法 - (NSInteger)numberOfSectionsInCollectionView:(UICollectionView...*)collectionView { return 1; } (2) 返回每个Section中Cell个数的方法 - (NSInteger)collectionView:(UICollectionView
一个很常见的需求就是在一个cell上点赞,评论等操作时,需要刷新单个cell对象,常用的方法即为: [self.tableView reloadRowsAtIndexPaths:[NSArray arrayWithObjects...indexPathForRow:index inSection:0],nil] withRowAnimation:UITableViewRowAnimationNone]; 仅仅这行代码会引起cell上下跳动的问题...,原因是 上述刷新过程中,虽然我们已经设置UITableViewRowAnimationNone,但任然会默认添加隐式动画效果。...withRowAnimation:UITableViewRowAnimationNone]; }]; 方法2: [UIView animateWithDuration:0 animations:^{ [collectionView...performBatchUpdates:^{ [collectionView reloadItemsAtIndexPaths:@[[NSIndexPath indexPathForItem
今天深圳总公司的iOS大佬来广州,给我这个小白一对一讲解了很多iOS的相关知识,受益匪浅,就赶快记下来以免以后忘记啦~ iOS相比安卓最大的特点就是非开源,软件之间无法获取数据,对于要获取照片/麦克风等的时候均需要获取权限才有访问资格...一、关于iphoneX的适配问题 适配这个问题分为两种: 头部Nav:1、用苹果自己的组件(如左图);2、自定义写的(如右图) (如何区分:一个app的自带头部Nav只有一种颜色,且一般左边为返回,中部为文字...自带的会自动适配iphoneX上面突出部分; 而写的现在开发的解决方法是:老项目——将其下移,突出部分填充黑色;新项目——做一套,检测为iphoneX时用。 底部Tab bar同理。...排列方式,主要有以下两种:tableview(左)和collectionview(右) ?...cell像是tableview/collectionview的细胞,很多cell组成了一个tableview/collectionview(如上图橙色部分)。 ?
注意,本文所有崩溃的原因都是同一个 EXC_BAD_ACCESS (code=1, address=0x11f645b98) image-20210423232626879 第一个堆栈:字典扩容 image...image-20210423234457157 第五个堆栈:释放对象 image-20210423234803386 signal SIGABRT image-20210423233946401 第一个崩溃堆栈...:释放内存(free) image-20210423234007713 第二个崩溃堆栈:释放内存(free_small_botch) image-20210423235112730
使用 根据类型获取cell让你的cell声明Reusable或NibReusable协议 //如果cell定义在xib中,声明NibReusableclass MyCustomCell: UITableViewCell..., NibReusable { } //如果cell是基于纯代码的,声明Reusableclass MyCustomCell: UITableViewCell, Reusable { } 接着在tableview...或者collectionView中register tableView.register(UINib.init(nibName: "MyCustomCell", bundle: nil), forCellWithReuseIdentifier...: "MyCustomCell") 粗暴的直接获取cell就可以啦: func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath...根据类型获取xib中的UIView对象 UIView对象声明NibLoadable协议。
进阶篇 最近遇到一个需求,对tableView有中级优化需求 要求 tableView 滚动的时候,滚动到哪行,哪行的图片才加载并显示,滚动过程中图片不加载显示; 页面跳转的时候,取消当前页面的图片加载请求...: 如果cell没进入到界面中(还不可见),不会调用- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath...decelerate){ //直接停止-无动画 [self p_loadImage]; }else{ //有惯性的-会走`scrollViewDidEndDecelerating...在下载完成的回调中?如果你在下载完成的时候再切割,此时 YYWebImage 缓存中的图片是初始图片,还是圆角图片?(终于等到3了!!)...进行圆角切割,再存储到 cache中,就能保证以后每次拿到的就都是cacha中已经裁切好的圆角图片 详情可见: NSString *path = [[UIApplication sharedApplication
领取专属 10元无门槛券
手把手带您无忧上云