当前位置: 首页 > news >正文

网页网站开发手机游戏百度推广服务费一年多少钱

网页网站开发手机游戏,百度推广服务费一年多少钱,统一社会信用代码查询,做兼职靠谱的网站一、五种跳转方式 1.wx.navigateTo() 保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面 通常推荐使用 wx.navigateTo进行跳转,以便返回原页面,以提高加载速度 wx.navigateTo({url: })2.wx.redirectTo() 关闭当前页面&#x…

一、五种跳转方式

1.wx.navigateTo()

保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面

通常推荐使用 wx.navigateTo进行跳转,以便返回原页面,以提高加载速度

wx.navigateTo({url: ''
})

2.wx.redirectTo()

关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面

wx.redirectTo({url: ''
})

3.wx.reLaunch()

关闭所有页面,打开到应用内的某个页面

wx.reLaunch()与 wx.redirectTo()的用途基本相同, 只是 wx.reLaunch()先关闭了内存中所有保留的页面,再跳转到目标页面

wx.reLanch({url: ''
})

4.wx.switchTab()

跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面

对于跳转到 tabBar 的页面,最好选择 wx.switchTab(),它会先关闭所有非 tabBar 的页面。其次,也可以选择 wx.reLaunch(),它也能实现从非 tabBar 跳转到 tabBar,或在 tabBar 间跳转,效果等同 wx.switchTab()。使用其他跳转 API 来跳转到 tabBar,则会跳转失败

wx.switchTab({url: ''
})

5.wx.navigateBack

关闭当前页面,返回上一页面或多级页面。可通过getCurrentPages 获取当前的页面栈,决定需要返回几层

这个 API 需要填写的参数只有 delta,表示要返回的页面数。若 delta 的取值大于现有可返回页面数时,则返回到用户进入小程序的第一个页面。当不填写 delta 的值时,就默认其为 1(注意,默认并非取 0),即返回上一页面


wx.navigateBack({delta: 1
})

二、跳转问题汇总(不定时更新)

微信小程序路由跳转有个隐藏的坑,就是 wx.navigateTo打开新页面,最多只能打开10个,超过10个之后就没反应,控制台也不会报错。

方案一:简单粗暴navigateTo不行,用redirectTo

小程序路由跳转的方式有五种,分别是wx.navigateTo(打开新页面,新页面入栈)、wx.redirectTo(重定向,当前页面出栈,新页面入栈)、wx.navigateBack(返回,页面不断出栈,直到目标返回页)、wx.switchTab(切换tab页面,页面全部出栈,只留下新的 Tab 页面)、wx.reLaunch(页面全部出栈,只留下新的页面)由此产生了第一种方式,当页面栈超过 10 时,直接用redirectTo。但这样太粗暴了,显然很多场景是需要保留访问过的页面的,由此有了方案一的升级版。

方案一升级版:根据页面栈决定当前跳转方式

每次跳转先去页面栈中查找目标页面是否已经访问过,如果访问过则用wx.navigateBack返回,如果没有访问过则判断页面栈中是否已经有10个页面,有则用wx.redirectTo,没有则navigateTo

class RouteMap {constructor(opt={}) {this.MAX_DEEP = opt.MAX_DEEP || 10this.IS_AUTO_BACK = opt.IS_AUTO_BACK || truethis.PAGE_STACk = getCurrentPages()}_findPageInHistory(path) {const { PAGE_STACk } = thislet delta = -1for (let i = 0; i < PAGE_STACk.length; i++) {if (PAGE_STACk[i].route === path) {delta = i + 1 // 目标页在栈中的位置break}}return delta}_dataToUrlQuery(data={}) {let query = '?';const prop in data) {if (data.hasOwnProperty(prop)) {const value = data[prop];query += `${prop}=${value}&`}}return query.replace(/&$/,'');}goPage(opt) {if (!opt) return new Error('缺少参数')if (opt && !opt.path) '缺少跳转目标path')const pageStackLen = PAGE_STACk.lengthlet { path,data } = optlet delta = this._findPageInHistory(path)path = '/' + path.replace(/^\//,0);">'') + this._dataToUrlQuery(data)if (delta > -1 && this.IS_AUTO_BACK) {// 如果有目标页已经是被访问过的const backPage = PAGE_STACk[pageStackLen - delta]backPage.setData({data});wx.navigateBack({delta: pageStackLen - delta})} else {if (pageStackLen < this.MAX_DEEP) {wx.navigateTo({url: path})} else {wx.redirectTo({url: path})}}}}module.exports = RouteMap

但是这样依然有问题,页面传参数变得无法统一,而且明明是前进页面,用户使用的时候很可能看着就是返回了几个页面。

方案二:在小程序页面栈之外维护多一个自己的逻辑栈

详细细节见该博客

http://www.ds6.com.cn/news/53620.html

相关文章:

  • 做b2b网站项目技巧网络推广公司名字
  • 重庆云端设计网站建设seo推广外包企业
  • 做网站买了域名之后百度信息流推广教程
  • 淄博做网站58同城培训中心
  • dz论坛源码做seo推广公司
  • 深圳电商网站帮忙推广的平台
  • 电脑网站开发2023年10月疫情还会严重吗
  • 杭州网站排名优化公司搜狗链接提交入口
  • 有什么网站可以做微信支付宝百度关键词推广价格
  • c 小说网站开发教程自媒体是什么
  • 天津网站建设模板网站排名在线优化工具
  • 效果图网站源码查询网域名查询
  • 东莞企业网站制作出售google ads
  • ps做兼职在什么网站可以找到优化 seo
  • 章丘网站建设优化步骤
  • ios开发者网站广州百度seo排名优化
  • 做英文网站可以申请补贴吗芭嘞seo
  • 上海网站建设 方案关键词排名推广软件
  • 网站开发科技公司营销策略有哪些
  • 中国太平保险集团官方网站平台做推广的技巧
  • 番禺做网站电话销售如何快速吸引客户
  • 金融行业网站建设公司电脑培训速成班多少钱
  • wordpress yoast seo 汉化长沙seo排名外包
  • 定制型网站设计报价表免费网站免费
  • 如何在招聘网站上选个好公司做销售seo整站优化技术培训
  • 做企业网站的合同关联词有哪些小学
  • 寺庙网站建设方案营销策划运营培训机构
  • 青海网站建设公司google怎么推广
  • 做网站低价域名查询ip网站
  • 桂林北站附近的景点海外网络推广平台