码迷,mamicode.com
首页 > 微信 > 详细

微信小程序Page对象重写

时间:2019-04-04 15:57:29      阅读:572      评论:0      收藏:0      [点我收藏+]

标签:org   class   ==   tap   ons   load   程序   cal   对象   

关于重写微信小程序Page对象如下:

let orgainPage = Page; // 保存原本的Page对象
let basePage = function (data) {
  // 生成初始data,如果页面已经有该值不在重新赋值
  if (typeof data.data.dataVal === ‘undefined‘) {
    data.data.dataVal = ‘具体值‘;
  }
  // 重写onLoad默认执行一些初始事件
  let orgainOnLoad = data.onLoad;
  data.onLoad = function (o) {
    // 执行的初始事件 start

    // 执行的初始事件 end
    orgainOnLoad.call(this, o);
  }
  // 默认初始方法,如果页面已经有该方法不在重写该方法
  if (typeof data.orgainFun !== ‘function‘) {
    data.orgainFun = function () {
      // 执行具体函数 start

      // 执行具体函数 end
    }
  }
  return orgainPage(data);
};

 

重写后的Page可以直接挂到App里面

App({
  onLaunch() { },
   // 直接挂到这边,新页面直接调用app.Base替换Page
  Base: basePage,
  globalData: {}
})

不直接重写Page是因为使用app.json插件时,不允许修改全局变量“Page”。

 

每个Page页面调用

const app = getApp();
app.Base({
  data: {
  }
})

页面必须有data,不然.call会报错

 

微信小程序Page对象重写

标签:org   class   ==   tap   ons   load   程序   cal   对象   

原文地址:https://www.cnblogs.com/sujianyin/p/10655163.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!