使用页面容器
[视频] 你好,我是李艺。上节课我们学习了使用recycle-view组件渲染长列表内容。这节课我们学习使用页面容器。 有时候我们在页面上会弹出一些特定的半屏窗口,例如登录窗口。这时候如果用户在iOS设备上使用了左滑手势或者是在Android设备上单击了物理返回键,会造成页面跳转到上一个页面,这在大多数情况下它并不是用户的真实本意,用户可能只是想将当前弹出的半屏的假页面给它关掉。 为了解决这个矛盾,小程序提供了页面容器组件,使用这个组件,在iOS用户做出左滑手势及Android用户单击物理返回键以及在代码里边调用了wx.navigateBack接口的时候仅是关闭这个容器,它并不会跳出当前这个页面。同时该页面容器还可以放在自定义的组件里面,像一个独立的组件那样去定义和使用。这可以让项目代码结构变得更加的清晰。下面我们看实例演示。 如何使用页面容器及如何自定义组件page-container? 就是这个页面容器组件,它是一个标准组件,它不需要引入就可以使用了,下面我们会创建一个自定义的组件login,在自定义组件里面使用page-container组件,当需要登录的时候,我们让login组件从这个页面的底部划出来然后再取消,或者是完成登录的时候调用自定义组件的close方法将半屏的假页面进行关掉,完成以后这个页面效果大概是像我们现在屏幕上看到的这样一个截图这个样子。 现在我们在屏幕上看到的这个是组件的wxml代码,其中第二行里面有一个position属性它是控制面板从底部划出的。它的show属性控制面板是否显示有两处wxml,这个节点的tap事件绑定到了这个close方法之上,无论是单击到哪一个地方close方法都是会被调用的,它是用于关闭我们当前的登录面板了。我们现在在屏幕上看到的是组件的JS代码,在这个方法close里边先尝试使用了wx.navigateBack然后进行退出。如果当前小程序页面栈里面它有页面调用会成功,反之如果是当前这个页面它是启动页或者是当前这个页面前面它没有页面了则会调用失败。在调用失败的时候也没有关系,可以再尝试使用setData改变数据属性visible,然后以此来关闭我们的一个面板。 现在我们在屏幕上看到的是这个组件的样式代码,这样式代码也没有什么稀奇的地方。主要是为了实现整个组件的一个外观,这个组件的外观它需要向我们用户提示,需要获取它的昵称、头像、性别等等这些信息。这些都是在微信小程序设计规范里边所规定的一些内容。我们需要按照这样的一个规范去设计我们的页面。现在我们在屏幕上看到的是我们组件在使用的时候,配置文件里面的一个配置信息以及在wxml里面的使用的信息,在wxml这个代码里面给了一个登录按钮,添加了一个tap事件监听,如我们现在看到的代码它是事件监听方法showLoginPanel的这样的一个代码。当单击我们登录按钮的时候,它会从底部然后打开我们登录面板。 下面我们进行实践一的代码演示如何使用页面容器及自定义组件。 首先我们需要在我们这个项目里面去实现一个自定义组件,在我们component 就是新的一个目录下,现在这个目录目前还不存在,我们看一下我们最终的,最终源码里边的它的一个实现情况,找到我们的2.3目录,然后这有一个components,这有一个目录,这个里面有一个login的组件。这个组件就是我们要实现的对吧,我们可以将这个目录拷贝一下,然后进到这个目录里面,进到资源管理器里面将整个目录给它拷贝一下,然后回到小程序项目里面,然后在这个地方再打开我们的资源管理器。 然后拷贝到这个地方,这个组件就已经进来了,我们看一下这个login组件我们主要做了什么事情?首先在wxml里面,外层我们使用了一个page-container这样的页面容器组件,然后它有一个show这样的一个属性,用visible然后去控制它的一个显示,后面position等于bottom它是控制它从底部进行滑出,这是它两个重要的属性。里边这些是我们实现的一个界面UI。这个界面UI是参照微信小程序设计规范而设计的,因为规范里面也有提到当我们想向用户去申请授权的时候,我们应该明确地告诉用户我们在申请什么样的一个权限,要获取他的什么样的信息 对吧,所以这个地方我们把这些信息都要给它设计上。 这是这样的一个。然后我们再看一下它的JS代码,这个地方是一个属性然后show属性默认等于false,这地方是一个属性监听。监听show属性如果它变化的时候,我们就设置visible等于它的新值,这是data对象里面visible控制组件的显示。method里面有两个方法一个是这个login,这个login我们是在我们这个里边有一个叫做确认地方。 这个button它有一个特殊的open-type等于getUserInfo,这是我们特殊的一个类型用于获取用户的信息,这个地方有一个事件监听就是catchgetuserinfo等于login绑定到我们这个方法上面,我们可以通过这个事件对象的detail这个信息去间接地去获取userInfo信息。当然这个里面它有其他的一些加密信息,加上这些信息,如果是我们一起传给后端的话那就可以进一步的解密得到 openId及unionId等等这些其他的一些信息了。这个地方我们是简单地将我们userInfo信息取出来,然后复制到我们globalData就是全局的对象上面去,然后以备后面使用,同时后面就调到close,close这个方法首先我们去尝试用navigateBack去调用了一下。 因为这个方法它是有客户端和版本限制的,它其实我们不能保证所有的情况下它都可以调用成功,所以这个地方我们要有一个判断。如果是它这种方式调用不成功的话,我们就用setData这种传统的方式去设置visible等于false来关闭这样的一个登录面板,这是它的一个主要代码。这个组件代码已经有了,至于另外的两个文件是样式,这些其实都没有什么好讲的,都是根据组件的需要然后去实现的。 下面在我们用户主页里面。在my这个文件里面开始去引入这个文件,用usingComponents,然后是login写它的地址,这个地址简单起见我们可以用拷贝大法对吧,先把相对路径拷贝过来然后再稍微地修改一下这样就可以了。引入以后就是使用,在我们wxml的文件的最下方,因为我们想放在页面的最上面所以我们要放在最下方,给它一个loginPanel这样的一个id。这个页面里面有一个登录的一个button,可以找一下在这个地方有登录的button ,所以这个地方给它加一个tap的事件的一个监听,然后在这个事件监听里面,就是我们想单击以后就是弹出我们的登录面板。这个地方加一个showLoginPanel,这是我们绑定的方法,把这个名字拷贝一下然后在我们的这个里边。这个方法我们应该还没有实现对吧,然后在这个里面去添加。 这个方法的一个实现,这个地方我们想去控制我们登录面板的显示一共是有两种方式: 第一种方式是使用数据绑定的这种方式。比如说我们现在搞一个showLogin这样的一个数据属性 默认等于false,然后我们将属性绑定在我们的组件上面,就放在这个地方,它有一个show的属性对不对,我们绑定在这个上面,在想弹出这个面板的时候,只需要用setData去设置showLogin等于true 这样就可以了。代码已经搞完了,现在我们单击编译看一下它的运行表现,然后普通编译我们可以选择我们的用户主页作为起始页面进行测试,然后单击登录,然后我们这个面板出来了对吧,可以取消,单击确认,可以发现我们userInfo信息也已经拿到了,这是一种显示我们面板的一种做法。 另外还有一种做法,更简单一种做法是我们不需要数据属性。不要这个数据属性,然后这个地方这个也不需要绑定。然后只需要拿id 给它一个id在这个地方,我们用页面的selectComponent这个方法,然后将id传给它以后我们就可以调用setData方法了。setData它里面我们还记得它有一个什么样的数据visible对吧,visible等于true 直接调到这个方法visible等于true,我们看一下这个表现,然后单击,也可以对不对。这种方式实现的效果跟我们刚才实现那种实现方式效果是一样的。但是我们这种方式不需要在这个页面里边去定义新的数据属性了,对不对?只需要然后查找这个组件然后调用它的方法就可以了,这种方式更简洁对不对?也不需要在wxml里面去绑、去做数据绑定了。 我们知道我们组件上其实它还有一个属性就是show属性,如果是我们直接去改变show属性,这种方式是不是也可以。比如说我们查到这个组件以后直接改了show等于true,然后上面这个先注掉,然后这样再测试一下,然后单击登录按钮。不行,这种方式不可以,所以我们就用上面这种方式就好了。这种方式是可以的,再测试一下,都可以,在我们面板里面这个取消与下面这个取消,其实它都绑定了close,因为我们用了page-container,因为我们知道它还可以响应什么,可以响应模拟操作对吧。我们比如说单击返回,这个不可以。 代码演示就到这里。 最后我们总结一下使用自定义组件的好处。page-container组件不仅可以响应iOS左滑这样的一个事件以及Android物理返回键这样的一个操作,它还默认实现了从页面的各个方向动画出场的一些效果 。对于开发者而言其实实在没有必要再造轮子实现各种浮窗组件了,类似的需求都可以基于page-container这样的一个页面容器组件然后以自定义组件的方式进行实现。 自定义组件是一种很好的封装页面视图功能的一种方式,它至少有以下优点,我们一起看一下: 第一点它可以复用,可以在各个页面里边使用,不需要重复定义; 第二点它可以将视图样式按组件进行划分,使样式代码更加清晰; 第三点就是它可以缩小setData的一个作用范围,当这个组件的数据发生变化的时候,重渲染机制它仅局限于当前组件内部发生作用,这在一定程度上也提高了视图的一个渲染的效率,现在我们在屏幕上看到的是这节课用到的一些文档地址。 这节课我们就讲到这里。 点击查看文档 这节课我们主要学习了容器组件如何使用,了解了自定义组件的好处我们自定义的login组件将负责接管所有页面的登录请求。这种组件化的开发方式它既让代码更加易于维护也避免了相似登录逻辑的一个重复编写。在一定程度上减少了代码包的一个体积,隐隐之中还提升了这个页面的渲染的效率,可以说是有百利而无一害。 下节课我们学习如何在用户主页页面里面优化动画效果。这里有一个问题请你思考一下:在HTML5页面开发里面有一种响应式设计方式。一种典型的页面效果是这样的:当用户向下滑动页面的时候页面上的元素它以不同的动画方式,从临时状态过渡到最终的目标状态,人类的眼睛对静态元素他感知是不灵敏的,但是对变化的元素的感知却是很灵敏的。使用响应式设计可以显著提升用户对这个页面上指定内容的一个关注度,在这个小程序里面我们怎么样去实现这种响应式的一个设计? 这个问题先留给你思考一下,下节课我们一起来深入探讨一下这个问题。