[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-7060":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":16,"stars7d":16,"stars30d":17,"stars90d":16,"forks30d":16,"starsTrendScore":16,"compositeScore":18,"rankGlobal":10,"rankLanguage":10,"license":19,"archived":20,"fork":20,"defaultBranch":21,"hasWiki":22,"hasPages":20,"topics":23,"createdAt":10,"pushedAt":10,"updatedAt":43,"readmeContent":44,"aiSummary":45,"trendingCount":16,"starSnapshotCount":16,"syncStatus":17,"lastSyncTime":46,"discoverSource":47},7060,"JXSegmentedView","pujiaxin33\u002FJXSegmentedView","pujiaxin33","A powerful and easy to use segmented view (segmentedcontrol, pagingview, pagerview, pagecontrol, categoryview) (腾讯新闻、今日头条、QQ音乐、网易云音乐、京东、爱奇艺、腾讯视频、淘宝、天猫、简书、微博等所有主流APP分类切换滚动视图)","",null,"Swift",2883,419,36,62,0,2,29.87,"MIT License",false,"master",true,[24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42],"category","categoryview","collectionview","indicator","page","pagecontrol","paging","pagingview","scrollview","segment","segmented","segmentedcontrol","segmentedview","split","swift","switch","uipagecontrol","uipageviewcontroller","uisplitviewcontroller","2026-06-12 02:01:34","\u003Cdiv align=center>\u003Cimg src=\"Example\u002FJXSegmentedViewExample\u002FImage\u002FJXSegmentedViewSmall.png\" width=\"467\" height=\"84\" \u002F>\u003C\u002Fdiv>\n\n[![platform](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Fplatform-iOS-blue.svg?style=plastic)](#)\n[![languages](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Flanguage-swift-blue.svg)](#) \n[![cocoapods](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Fcocoapods-supported-4BC51D.svg?style=plastic)](https:\u002F\u002Fcocoapods.org\u002Fpods\u002FJXSegmentedView)\n[![carthage](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FCarthage-compatible-4BC51D.svg?style=flat)](https:\u002F\u002Fgithub.com\u002FCarthage\u002FCarthage\u002F)\n[![support](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002Fsupport-ios%208%2B-orange.svg)](#) \n\n[There is an English document here, click to view](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FREADME-English.md)\n\nA powerful and easy to use segmented view (segmentedcontrol, pagingview, pagerview, pagecontrol, categoryview) (腾讯新闻、今日头条、QQ音乐、网易云音乐、京东、爱奇艺、腾讯视频、淘宝、天猫、简书、微博等所有主流APP分类切换滚动视图)\n\n与其他的同类三方库对比的优点：\n- 指示器逻辑面向协议编程(Protocol Oriented Programming)，可以为所欲为的扩展指示器效果；\n- 提供更加全面丰富效果，几乎支持所有主流APP效果；\n- 使用子类化管理cell样式，逻辑更清晰，扩展更简单；\n- 列表支持整个生命周期方法；\n\n## Objective-C版本\n\n如果你在找Objective-C版本，请点击查看\n[JXCategoryView](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXCategoryView)\n\n## 效果预览\n\n### 指示器效果预览\n\n说明 | Gif |\n----|------|\nLine固定宽度  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FLineFixedWidth.gif\" width=\"350\" height=\"80\"> |\nLine与cell等宽  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FLineFlexibleWidth.gif\" width=\"350\" height=\"80\"> |\nLine延长  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FLineLengthen.gif\" width=\"350\" height=\"80\"> |\nLine延长+偏移  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FLineLengthenOffset.gif\" width=\"350\" height=\"80\"> |\nRainbowLine🌈彩虹  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FLineRainbow.gif\" width=\"350\" height=\"80\"> |\nDotLine点线 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FLineDot.gif\" width=\"334\" height=\"80\"> |\nDoubleLine双线  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FLineDouble.gif\" width=\"350\" height=\"80\"> |\nTriangle三角形底部  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FTriangle.gif\" width=\"350\" height=\"80\"> |\nTriangle三角形顶部  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FTriangleTop.gif\" width=\"350\" height=\"80\"> |\nBackground椭圆形  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorBackground.gif\" width=\"350\" height=\"80\"> |\nBackground椭圆形+阴影  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorBackgroundShadow.gif\" width=\"350\" height=\"80\"> |\nBackground遮罩有背景  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorBackgroundMask.gif\" width=\"350\" height=\"80\"> |\nBackground遮罩无背景  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorBackgroundMaskPure.gif\" width=\"350\" height=\"80\"> |\nBackground渐变色\u003Cbr>(渐变是固定的)  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorBackgroundGradient.gif\" width=\"350\" height=\"80\"> |\nGradient渐变色\u003Cbr>(渐变随着位置变动)  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorGradient.gif\" width=\"350\" height=\"80\"> |\nImage底部  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorImageBottom.gif\" width=\"350\" height=\"80\"> |\nImage背景  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorImageBG.gif\" width=\"350\" height=\"80\"> |\n混合使用 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FIndicator\u002FIndicatorMixed.gif\" width=\"350\" height=\"80\"> |\n\n以下指示器支持上下位置切换：\n`JXSegmentedIndicatorLineView`、`JXSegmentedIndicatorRainbowLineView`、`JXSegmentedIndicatorDotLineView`、`JXSegmentedIndicatorDoubleLineView`、`JXSegmentedIndicatorTriangleView`、`JXSegmentedIndicatorImageView`\n\n### Cell样式效果预览\n\n说明 | Gif |\n----|------|\n颜色渐变  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FColorGradient.gif\" width=\"350\" height=\"80\"> |\n文字渐变  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTextGradient.gif\" width=\"350\" height=\"80\"> |\n大小缩放  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FZoomOnly.gif\" width=\"350\" height=\"80\"> |\n大小缩放+字体粗细  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FZoomStrokeWidth.gif\" width=\"350\" height=\"80\"> |\n大小缩放+点击动画  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FZoomAnimation.gif\" width=\"350\" height=\"80\"> |\n大小缩放+cell宽度缩放  |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FZoomCellWidth.gif\" width=\"350\" height=\"80\"> |\nTitleImage_Top |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTitleImageTop.gif\" width=\"350\" height=\"80\"> |\nTitleImage_Left |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTitleImageLeft.gif\" width=\"350\" height=\"80\"> |\nTitleImage_Bottom |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTitleImageBottom.gif\" width=\"350\" height=\"80\"> |\nTitleImage_Right |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTitleImageRight.gif\" width=\"350\" height=\"80\"> |\nTitleImage_只有图片 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTitleImageOnlyImage.gif\" width=\"350\" height=\"80\"> |\nTitleOrImage(高仿腾讯视频) |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTitleOrImage.gif\" width=\"350\" height=\"80\"> |\n数字 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FNumber.gif\" width=\"350\" height=\"80\"> |\n红点 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FCellDot.gif\" width=\"350\" height=\"80\"> |\n多行富文本 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FTitleAttributed.gif\" width=\"350\" height=\"80\"> |\n多种cell混用 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FCell\u002FMixedCell.gif\" width=\"350\" height=\"80\"> |\n\n### 特殊效果预览\n\n说明 | Gif |\n----|------|\n数据源过少\u003Cbr\u002F> isItemSpacingAverageEnabled为true |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FSpecial\u002FItemAveTrue.gif\" width=\"350\" height=\"80\"> |\n数据源过少\u003Cbr\u002F> isItemSpacingAverageEnabled为false |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FSpecial\u002FItemAveFalse.gif\" width=\"350\" height=\"80\"> |\nSegmentedControl\u003Cbr\u002F>参考[`SegmentedControlViewController`](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FExample\u002FJXSegmentedViewExample\u002FSpecial\u002FSegmentedControl\u002FSegmentedControlViewController.swift)类 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FSpecial\u002FSegmentedControl.gif\" width=\"350\" height=\"80\"> |\n导航栏使用\u003Cbr\u002F>参考[`NaviSegmentedControlViewController`](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FExample\u002FJXSegmentedViewExample\u002FSpecial\u002FSegmentedControl\u002FNaviSegmentedControlViewController.swift)类 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FSpecial\u002FNavigationBar.gif\" width=\"350\" height=\"80\"> |\n嵌套使用\u003Cbr\u002F>参考[`NestViewController`](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FExample\u002FJXSegmentedViewExample\u002FSpecial\u002FNest\u002FNestViewController.swift)类 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FSpecial\u002FNest.gif\" width=\"350\" height=\"200\"> |\n个人主页(上下左右滚动、header悬浮)\u003Cbr\u002F>参考[`PagingViewController`](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FExample\u002FJXSegmentedViewExample\u002FSpecial\u002FPersonal\u002FPagingViewController.swift)类\u003Cbr\u002F> 更多样式请点击查看[JXPagingView库](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXPagingView) |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FSpecial\u002FPersonal.gif\" width=\"350\" height=\"567\"> |\n数据加载&刷新\u003Cbr\u002F>参考[`LoadDataViewController`](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FExample\u002FJXSegmentedViewExample\u002FSpecial\u002FLoadData\u002FWithListContainerView\u002FLoadDataViewController.swift)类 |  \u003Cimg src=\"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXExampleImages\u002Fblob\u002Fmaster\u002FJXSegmentedView\u002FSpecial\u002FLoadData.gif\" width=\"350\" height=\"200\"> |\n\n\n## 要求\n\n- iOS 9.0+\n- Xcode 9+\n- Swift 5.0\n\n## 安装\n\n### 手动\n\nClone代码，把Sources文件夹拖入项目，就可以使用了；\n\n### CocoaPods\n\n```ruby\ntarget '\u003CYour Target Name>' do\n    pod 'JXSegmentedView'\nend\n```\n先执行`pod repo update`，再执行`pod install`\n\n### Carthage\n在cartfile文件添加：\n```\ngithub \"pujiaxin33\u002FJXSegmentedView\"\n```\n然后执行`carthage update --platform iOS` 即可\n\n### Swift Package Manager\n\n1.在Package.swift文件添加如下代码:\n```\ndependencies: [\n  .package(url: \"https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView.git\", from: \"1.2.1\")\n]\n```\n2.使用命令行构建:\n```\n$ swift build\n```\n\n## 使用\n\n### `JXSegmentedView`使用示例\n\n1.初始化JXSegmentedView\n```Swift\nsegmentedView = JXSegmentedView()\nsegmentedView.delegate = self\nview.addSubview(self.segmentedView)\n```\n\n2.初始化dataSource\n\n`dataSouce`类型为`JXSegmentedViewDataSource`协议。使用单独的类实现`JXSegmentedViewDataSource`协议，实现代码隔离。选择不同的类赋值给`dataSource`，就可以控制`JXSegmentedView`显示效果，实现插件化。比如选择`JXSegmentedTitleImageDataSource`类作为`dataSource`就选择了文字图片的显示效果；选择`JXSegmentedNumberDataSource`类作为`dataSource`就选择了文字加数字的显示效果；\n```Swift\n\u002F\u002FsegmentedDataSource一定要通过属性强持有，不然会被释放掉\nsegmentedDataSource = JXSegmentedTitleDataSource()\n\u002F\u002F配置数据源相关配置属性\nsegmentedDataSource.titles = [\"猴哥\", \"青蛙王子\", \"旺财\"]\nsegmentedDataSource.isTitleColorGradientEnabled = true\n\u002F\u002F关联dataSource\nsegmentedView.dataSource = self.segmentedDataSource\n```\n\n3.初始化指示器indicator\n```Swift\nlet indicator = JXSegmentedIndicatorLineView()\nindicator.indicatorWidth = 20\nsegmentedView.indicators = [indicator]\n```\n\n4.可选实现`JXSegmentedViewDelegate`代理\n```Swift\n\u002F\u002F点击选中或者滚动选中都会调用该方法。适用于只关心选中事件，而不关心具体是点击还是滚动选中的情况。\nfunc segmentedView(_ segmentedView: JXSegmentedView, didSelectedItemAt index: Int) {}\n\u002F\u002F 点击选中的情况才会调用该方法\nfunc segmentedView(_ segmentedView: JXSegmentedView, didClickSelectedItemAt index: Int) {}\n\u002F\u002F 滚动选中的情况才会调用该方法\nfunc segmentedView(_ segmentedView: JXSegmentedView, didScrollSelectedItemAt index: Int) {}\n\u002F\u002F 正在滚动中的回调\nfunc segmentedView(_ segmentedView: JXSegmentedView, scrollingFrom leftIndex: Int, to rightIndex: Int, percent: CGFloat) {}\n```\n\n### `contentScrollView`列表容器使用示例\n\n#### 直接使用`UIScrollView`自定义使用示例\n\n因为代码比较分散，而且代码量也比较多，所有不推荐使用该方法。要正确使用需要注意的地方比较多，尤其对于刚接触iOS的同学来说不太友好。\n\n不直接贴代码了，具体点击[LoadDataCustomViewController](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FExample\u002FJXSegmentedViewExample\u002FSpecial\u002FLoadData\u002FListCustom\u002FLoadDataCustomViewController.swift)查看源代码了解。\n\n作为替代，官方使用&强烈推荐使用下面这种方式👇👇👇。\n\n#### 配合`JXSegmentedListContainerView`封装类使用示例\n\n`JXSegmentedListContainerView`是对列表视图高度封装的类，具有以下优点：\n- 相对于直接使用`UIScrollView`自定义，封装度高、代码集中、使用简单；\n- 列表懒加载：当显示某个列表的时候，才进行列表初始化。而不是一次性加载全部列表，性能更优；\n- 可以选用CollectionView作为列表容器，内存管理更加优秀；\n- 支持列表的整个生命周期方法调用；\n\n1.初始化`JXSegmentedListContainerView`\n```Swift\nlistContainerView = JXSegmentedListContainerView(dataSource: self)\nview.addSubview(self.listContainerView)\n\u002F\u002F关联listContainer\nsegmentedView.listContainer = listContainerView\n```\n\n2.实现`JXSegmentedListContainerViewDataSource`代理方法\n```Swift\n\u002F\u002F返回列表的数量\nfunc numberOfLists(in listContainerView: JXSegmentedListContainerView) -> Int {\n    return segmentedDataSource.titles.count\n}\n\u002F\u002F返回遵从`JXSegmentedListContainerViewListDelegate`协议的实例\nfunc listContainerView(_ listContainerView: JXSegmentedListContainerView, initListAt index: Int) -> JXSegmentedListContainerViewListDelegate {\n    return ListBaseViewController()\n}\n```\n\n3.列表实现`JXSegmentedListContainerViewListDelegate`代理方法\n\n不管列表是UIView还是UIViewController都可以，提高使用灵活性，更便于现有的业务接入。\n```Swift\n\u002F\u002F\u002F 如果列表是VC，就返回VC.view\n\u002F\u002F\u002F 如果列表是View，就返回View自己\n\u002F\u002F\u002F - Returns: 返回列表视图\nfunc listView() -> UIView {\n    return view\n}\nfunc listWillAppear() {}\nfunc listDidAppear() {}\nfunc listDidDisappear() {}\nfunc listDidDisappear() {}\n```\n\n具体点击[LoadDataViewController](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FExample\u002FJXSegmentedViewExample\u002FSpecial\u002FLoadData\u002FWithListContainerView\u002FLoadDataViewController.swift)查看源代码了解\n\n### 使用总结\n\n因为`JXSegmentedView`本身支持许多特性：指示器、cell样式、列表容器等，如何有序管理好代码成了一个难题。借助于协议、继承、封装类极大的简化了使用难度，而且提高了灵活性，扩展相当容易。\n\n- 核心主类：`JXSegmentedView`\n- 数据源&cell样式定制类：遵从`JXSegmentedViewDataSource`协议的类\n- 指示器类：遵从`JXSegmentedIndicatorProtocol`协议的`UIView`类\n- 列表容器：官方推荐`JXSegmentedListContainerView`类，特殊情况可以使用`UIScrollView`自定义\n\n## 指示器样式自定义\n\n- 需要继承`JXSegmentedIndicatorProtocol`协议，点击参看[JXSegmentedIndicatorProtocol](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FSources\u002FIndicator\u002FJXSegmentedIndicatorProtocol.swift)\n- 提供了继承`JXSegmentedIndicatorProtocol`协议的基类`JXSegmentedIndicatorBaseView`，里面提供了许多基础属性。点击参看[JXSegmentedIndicatorBaseView](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FSources\u002FIndicator\u002FJXSegmentedIndicatorBaseView.swift)\n- 自定义指示器，请参考已实现的指示器视图，多尝试、多思考，再有问题请提Issue或加入反馈QQ群\n\n\n## dataSource和Cell自定义\n\n- 需要继承`JXSegmentedViewDataSource`协议，点击参看[JXSegmentedViewDataSource](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FSources\u002FCore\u002FJXSegmentedView.swift)\n- 提供了继承`JXSegmentedViewDataSource`协议的基类`JXSegmentedBaseDataSource`，里面提供了许多基础属性。点击参看[JXSegmentedBaseDataSource](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FSources\u002FCore\u002FJXSegmentedBaseDataSource.swift)\n- 任何自定义需求，dataSource、cell、itemModel三个都要子类化。即使某个子类cell什么事情都不做。用于维护继承链，以免以后子类化都不知道要继承谁了；\n- dataSource和Cell自定义，请参考已实现的dataSource，多尝试、多思考，再有问题请提Issue或加入反馈QQ群\n\n## 常用属性说明\n\n[常用属性说明文档地址](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E5%B8%B8%E7%94%A8%E5%B1%9E%E6%80%A7%E8%AF%B4%E6%98%8E.md)\n\n## 其他使用注意事项\n\n[其他使用注意事项文档总地址](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md)\n\n- [个人主页效果](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXPagingView)\n- [侧滑手势处理说明文档](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E4%BE%A7%E6%BB%91%E6%89%8B%E5%8A%BF%E5%A4%84%E7%90%86%E8%AF%B4%E6%98%8E%E6%96%87%E6%A1%A3.md)\n- [列表的生命周期方法处理](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E5%88%97%E8%A1%A8%E7%9A%84%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F%E6%96%B9%E6%B3%95%E5%A4%84%E7%90%86.md)\n- [JXSegmentedListContainerType的scrollView和collectionView对比](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#jxsegmentedlistcontainertype%E7%9A%84scrollview%E5%92%8Ccollectionview%E5%AF%B9%E6%AF%94)\n- [cell左滑删除](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#cell%E5%B7%A6%E6%BB%91%E5%88%A0%E9%99%A4)\n- [JXSegmentedView状态刷新](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#jxsegmentedview%E7%8A%B6%E6%80%81%E5%88%B7%E6%96%B0)\n- [reloadDataWithoutListContainer方法使用说明](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#reloaddatawithoutlistcontainer%E6%96%B9%E6%B3%95%E4%BD%BF%E7%94%A8%E8%AF%B4%E6%98%8E)\n- [listContainer或contentScrollView关联说明](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#listcontainer%E6%88%96contentscrollview%E5%85%B3%E8%81%94%E8%AF%B4%E6%98%8E)\n- [点击Item之后contentScrollView切换效果](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#%E7%82%B9%E5%87%BBitem%E4%B9%8B%E5%90%8Econtentscrollview%E5%88%87%E6%8D%A2%E6%95%88%E6%9E%9C)\n- [代码选中指定index](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#%E4%BB%A3%E7%A0%81%E9%80%89%E4%B8%AD%E6%8C%87%E5%AE%9Aindex)\n- [列表cell点击跳转示例](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#%E5%88%97%E8%A1%A8cell%E7%82%B9%E5%87%BB%E8%B7%B3%E8%BD%AC%E7%A4%BA%E4%BE%8B)\n- [禁止列表容器左右滑动](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#%E7%A6%81%E6%AD%A2%E5%88%97%E8%A1%A8%E5%AE%B9%E5%99%A8%E5%B7%A6%E5%8F%B3%E6%BB%91%E5%8A%A8)\n- [JXSegmentedView.collectionView高度取整说明](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#jxsegmentedviewcollectionview%E9%AB%98%E5%BA%A6%E5%8F%96%E6%95%B4%E8%AF%B4%E6%98%8E)\n- [对父VC的automaticallyAdjustsScrollViewInsets属性设置为false](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#%E5%AF%B9%E7%88%B6vc%E7%9A%84automaticallyadjustsscrollviewinsets%E5%B1%9E%E6%80%A7%E8%AE%BE%E7%BD%AE%E4%B8%BAfalse)\n- [单个cell刷新](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#%E5%8D%95%E4%B8%AAcell%E5%88%B7%E6%96%B0)\n- [自定义建议](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9.md#%E8%87%AA%E5%AE%9A%E4%B9%89%E5%BB%BA%E8%AE%AE)\n\n## 重要版本更新记录\n\n- 2019.10.9发布1.0.0版本，参考[1.0.0版本迁移指南](https:\u002F\u002Fgithub.com\u002Fpujiaxin33\u002FJXSegmentedView\u002Fblob\u002Fmaster\u002FDocument\u002F1.0.0%E7%89%88%E6%9C%AC%E8%BF%81%E7%A7%BB%E6%8C%87%E5%8D%97.md)\n\n## 补充\n\n如果刚开始使用`JXSegmentedView`，当开发过程中需要支持某种特性时，请务必先搜索使用文档或者源代码。确认是否已经实现支持了想要的特性。请别不要文档和源代码都没有看，就直接提问，这对于大家都是一种时间浪费。如果没有支持想要的特性，欢迎提Issue讨论，或者自己实现提一个PullRequest。\n\n该仓库保持及时更新，对于主流新的分类选择效果会第一时间支持。使用过程中，有任何建议或问题，可以通过以下方式联系我：\u003C\u002Fbr>\n邮箱：317437084@qq.com \u003C\u002Fbr>\nQQ群： 112440276\n\n\u003Cimg src=\"https:\u002F\u002Fnote.youdao.com\u002Fyws\u002Fpublic\u002Fresource\u002Fc6fa96a65e424afcf7f6304ddf5c283a\u002Fxmlnote\u002F8dc821d271c35845acff3f853f434bce\u002F3913\" width=\"300\" height=\"411\">\n\n喜欢就star❤️一下吧\n\n## License\n\nJXSegmentedView is released under the MIT license.\n","JXSegmentedView是一个功能强大且易于使用的分段视图组件，支持多种样式如分段控件、页面视图和分类视图等。它基于Swift开发，通过面向协议编程实现了高度可定制的指示器效果，并提供了丰富的预设样式以满足几乎所有主流iOS应用的需求，包括腾讯新闻、今日头条等。此外，该库采用子类化管理cell样式，使得逻辑更清晰且易于扩展；同时支持列表的整个生命周期方法，便于开发者进行更精细的控制。适用于需要实现复杂或自定义导航栏切换效果的应用场景。","2026-06-11 03:10:21","top_language"]