在智能小程序中,导航跳转是连接两个页面的纽带,由于框架导航实现底层原理的黑盒效应,以及页面容器的场景和类型不同,导致我们在开发小程序过程中,不能清晰的判断页面的一些表现,例如返回图标(客户端绘制的一个左箭头图标,位于顶部导航栏的最左侧,用于返回上一个小程序页面容器)与首页图标(客户端绘制的一个小房子图标,用于打开小程序 app.json 配置的首页)使用场景不明确。
通过对小程序框架进行分析,我们整理了全面的导航原理以及页面跳转后客户端的表现,希望为您的开发带来帮助。
更多内容参见:顶部导航栏的 UI 设计参考文档、导航路由开发文档、web-view 组件开发文档。
智能小程序提供了 5 种路由方式,即: navigateTo、redirectTo、navigateBack、switchTab、reLaunch,除直接调用 API 的方式,还可以通过 navigator 组件绑定属性的方式触发路由跳转。
假设从 A 页面跳转到 B 页面,针对 5 种不同的跳转,通过对智能小程序分析,客户端和小程序框架配合如下:
跳转方式 | 实现方式 | 场景 |
---|---|---|
navigateTo | 小程序框架携带开发者参数,通知客户端打开一个新的页面容器,客户端打开后将相关参数回传给小程序框架,并通知框架开始加载开发者代码,紧接着框架实例化一个新的页面并将其推入页面栈中,然后利用初始数据进行初始化页面渲染。 | 只能打开非 tabBar 页面 |
redirectTo | 小程序框架携带开发者参数,通知客户端打开一个新的页面容器,客户端打开后将相关参数回传给小程序框架,并通知框架开始加载开发者代码,紧接着框架将页面栈顶的信息更新为待跳转页面的信息,同时创建页面实例,然后利用初始数据进行初始化页面渲染。 | 只能打开非 tabBar 页面 |
navigateBack | 有两种方式返回上一个页面,一种是主动操作(android 物理返回、双端右滑、通过顶 bar 的返回按钮),此场景下返回时客户端会通知小程序框架将页面栈顶页弹出;另一种是调用 API 的方式或者利用 navigator 组件返回上一页,此场景下是由框架直接通知客户端关闭当前页面容器,客户端关闭成功后通知小程序框架将页面栈顶页弹出。 | 可作用于任意页面 |
switchTab | 有两种方式进行 tab 切换,一种是主动操作(在 tab 页点击另一个 tab),客户端会通知小程序框架对页面栈信息进行更新,另一种是通过 API 或利用 navigator 组件通知客户端跳转到某一 tab 页,客户端跳转完成时通知小程序框架进行页面栈信息更新。 | 只能打开 tabBar 页面 |
reLaunch | 小程序框架将页面栈清空,然后利用开发者传入的 url 重新初始化为第一个页面。 | 可打开任意页面 |
假设我们的所有页面都在原生小程序页面跳转:
navigationStyle: custom
),此时客户端就会隐藏掉原生顶部导航栏,开发者就可以通过标签样式进行定制化导航栏(未包括状态栏)。智能小程序官方并不推荐使用 web-view 组件承载 h5 页面。
因为这和原生小程序页面相比性能有极大的劣势,并不能给我们的用户带来更好的体验。但是,在初期阶段确实存在将 h5 页面先迁移到小程序中的诉求。
在 web-view 组件承载 h5 页面中,如果想要跳转到一个新的小程序页面(即客户端新开一个容器),需要配合 jssdk 进行操作。
当需要从 h5 无缝转接到小程序,首先想到的就是小程序内放置一个web-view
组件来链接之前的 h5 页面,一行代码就完成了迁移到小程序的难题。
实际情况如下图:
小程序,页面左上角没有返回按钮,只能不停的往下点,无法返回。
问题原因:
使用 web-view 组件的 h5 中跳转到 h5 的下一个页面,客户端并没有打开一个新的小程序页面,而是在当前 web-view 组件加载了新的网页,这样导致客户端的页面栈没有增加新的小程序页面,导航栏的返回按钮没有出现,导航栏上还是原来的按钮。
正常情况下,小程序直接打开一个非首页小程序页面,会出现首页图标,如未点击首页或者右上角“更多”里面的回首页或者首页图标,在跳转到新的小程序页面的时候,首页图标将会一直存在。
通过跳转新的小程序页面,比如在将要加载的 h5 也放个 web-view 组件,触发新的小程序页面加载,下一个页面的左上角是会有返回按钮,体验上和原生一致。
效果图:
那么问题来了,怎么把点击的链接传到第二个页面呢?
我们可以在 web-view 组件页面使用 jssdk 中 h5 页面跳转到小程序页面的方法 小程序.webView.navigateTo
,然后再携带一个 url 参数:
代码示例
navigate(url) {
swan.webView.navigateTo({url: '../webview/webview?weburl=' + url});
}
接着在小程序另外一个新的 web-view 组件页面中:
代码示例
Page({
data: {
url:''
},
// 监听页面加载,获取H5页面传递过来的weburl
onLoad: function (options) {
this.setData({
url: options.weburl
});
}
});
并赋值给 webview.小程序 中的 src 属性:
// pages/webview/webview.swan
navigationStyle: custom
),缺点:web-view 组件页面不支持自定义导航栏样式。点击返回按钮:
当我们从一个小程序打开另一个小程序,单个小程序间页面跳转参见原生小程序页面、web-view 组件撑起的 h5 页面,目前百度 App 客户端最多支持打开 6 个小程序,超出之后会按打开顺序依次替换掉最先打开的小程序,当用户主动进行小程序切换(点击右上角的关闭按钮,将当前小程序送入后台,或者在 android 多任务管理中直接切换到某一个小程序页面)时,会触发每个小程序的部分生命周期,并不会刷新导航栏。因此可以在跳转到某个小程序后,继续使用之前的导航跳转方法。
小程序间的导航流程图:
使用自定义导航栏时,请先参考原生顶部导航栏。通常情况下,为保证良好的用户体验,可能需要自己实现默认导航中的「返回/回首页」等功能,此时可以借助 getCurrentPages 来判断当前页面栈的深度,从而决定是否应该展示「返回/回首页」按钮。
当swanNativeVersion>=2.28.0
时,小程序框架将回收二级页面(非首页 / 非 Tab 页)左上角返回按钮的自定义权限。在小程序二级页面使用自定义导航栏时,小程序框架将提供统一的返回按钮控制方案。详情请参考非兼容性升级。
分享名称:创新互联百度小程序教程:小程序导航
分享URL:http://www.csdahua.cn/qtweb/news25/477375.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网