pageViewController实现多视图(控制器)滑动切换

先看一下效果动画


类似的界面做过不少,,在几个APP中都有用到过,,再次之前不了解uipageViewController 曾经的思路有两个现在想想都觉得繁琐,,

之前的思路1:使用嵌套,collectionview嵌套,每个item中添加内容

之前的思路2:使用scrollview 在上面创建一个一个的controller 实现左右滑动


这两个思路无疑是可以实现的 并且可以实现每个页面的重用,,滑动等都可以 唯独一点不好就是当停留在第一页的时候 点击标题栏第五页,,那么平移的过程就是第一页到第五页,,所有的页面从屏幕快速闪过,,并且看到现在很多APP都是这样的。。在此之前我是用的思路2,,为了避免跨页面切换出现的中间几个页面闪过的过程,,直接把平移动画关闭了。。直到使用了uipageViewController,,赶紧把项目中的给换掉了

代码不多150行以内


#import "ViewController.h"/// 当前controller

#import "MyViewController.h" /// 复用的controller 适用于每个控制器布局相同的情况下,,布局不同就创建不同的controller添加进来

#import "TitleCollectionViewCell.h"/// 标题栏使用的collectionviewcell


@interface ViewController ()<UIPageViewControllerDelegate,UIPageViewControllerDataSource,UICollectionViewDelegate,UICollectionViewDataSource>{

    记录当前页 当前标题位置

    NSInteger ld_currentIndex;

}

@property (nonatomic, strong) UIPageViewController *pageViewController;

@property (nonatomic, strong) NSMutableArray *controllersArr;/// 控制器数组

@property (nonatomic, strong) NSMutableArray *titleArray; /// 标题数组

@property (nonatomic, strong) UICollectionView *titleCollectionView; /// 标题collectionview


@end

@implementation ViewController


- (void)viewDidLoad {

    [super viewDidLoad];

    self.view.backgroundColor = [UIColor whiteColor];

    self.navigationController.navigationBar.translucent = NO;

    self.controllersArr = [NSMutableArray array];

    self.titleArray = [NSMutableArray array];

    如果controller布局相同则循环创建MyViewController 添加进数组,,如果controller 布局不同 那就创建多个不同controller依次添加数组

    for (int i = 0; i < 10; i++) {

        MyViewController *con = [[MyViewController alloc]init];

        [self.controllersArr addObject:con];

        NSString *str = [NSString stringWithFormat:@" %d "

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Thymeleaf视图控制器是指在Spring MVC应用程序中使用Thymeleaf作为视图解析器时,可以通过配置视图控制器来简化处理程序和视图之间的映射。 具体来说,Thymeleaf视图控制器可以将请求直接映射到Thymeleaf模板,而无需编写控制器代码。这样可以大大简化应用程序的配置和开发过程。 在Spring MVC应用程序中配置Thymeleaf视图控制器需要在配置类中添加以下代码: ```java @Configuration public class WebConfig implements WebMvcConfigurer { @Override public void addViewControllers(ViewControllerRegistry registry) { registry.addViewController("/home").setViewName("home"); registry.addViewController("/login").setViewName("login"); } } ``` 在上面的示例中,我们将“/home”请求映射到“home”模板,将“/login”请求映射到“login”模板。这样,当用户访问“/home”时,将直接渲染“home”模板,而无需使用控制器来处理请求。 ### 回答2: Thymeleaf是一个服务器端Java模板引擎,用于构建web应用程序的视图层。它遵循面向模板的设计思想,将模板和数据进行分离,通过填充模板来生成最终的HTML页面。 视图控制器是一个用于处理请求和返回响应的组件。在Thymeleaf中,视图控制器用于将请求映射到相应的视图,并处理视图中需要的数据。它负责接收来自用户的请求并确定需要显示的页面,然后将数据传递给该页面进行处理并返回给用户。 Thymeleaf视图控制器的主要作用是: 1. 路径映射:根据请求的URL路径将请求映射到对应的视图。通过在控制器中配置路径和对应的视图模板,Thymeleaf可以根据URL路径自动寻找匹配的视图,并将请求的数据填充到视图中。 2. 数据传递:将请求中的数据传递给视图进行处理。视图控制器可以从请求中获取参数、表单数据等信息,并将这些数据传递给视图进行处理。这样可以灵活地在视图中使用这些数据,并展示给用户。 3. 视图渲染:将处理后的数据填充到视图模板中,并将最终的HTML页面返回给用户。Thymeleaf视图控制器负责将数据填充到视图中的相应位置,并将处理后的HTML页面返回给用户。这样用户就可以在浏览器中看到经过处理的页面。 总之,Thymeleaf视图控制器在web应用程序中起着重要的作用,它能够根据请求的URL路径映射到相应的视图,并且能够处理传递给视图的数据。它使得开发人员可以更方便地构建和管理视图层,提高了开发效率和代码的可维护性。 ### 回答3: Thymeleaf是一种模板引擎,用于在后端和前端之间处理页面的渲染和数据绑定。它支持HTML,XML,JavaScript,CSS等各种页面,并且可以与Spring框架无缝集成。Thymeleaf作为视图控制器,主要负责处理请求并将结果返回给用户。 Thymeleaf视图控制器的作用是将请求映射到相应的处理方法,并根据处理方法的返回结果选择合适的视图进行渲染。在Spring MVC中,我们可以通过配置Thymeleaf视图控制器来指定处理方法与视图的映射关系。 Thymeleaf视图控制器有以下几个主要的配置选项: 1. Url映射:我们可以定义一个或多个Url的模式,将其映射到特定的处理方法。例如,可以将"/home"映射到HomeController中的home方法。 2. 视图名称:对于处理方法返回的结果,我们可以指定要渲染的视图的名称。这个名称通常与页面的逻辑地址对应。 3. 视图前缀和后缀:Thymeleaf视图控制器还可以配置视图的前缀和后缀。这些前缀和后缀会与视图名称组合在一起,以确定最终的视图文件。 4. 视图解析器:Thymeleaf视图控制器需要使用视图解析器来解析视图的名称和位置。我们可以配置一个或多个视图解析器,以便根据不同的策略来查找和渲染视图。 通过配置Thymeleaf视图控制器,我们可以轻松地将请求映射到相应的处理方法,并渲染正确的视图返回给用户。Thymeleaf简化了开发人员在后端和前端之间的交互,提高了开发效率,同时也使页面的渲染和数据绑定变得更加灵活和可定制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值