框架:逻辑层

核心

一个响应式数据绑定系统

  • View 视图
  • App Service 逻辑

文件结构

根目录:

  • app.js 小程序逻辑(require)
  • app.json 小程序公共设置(require)
  • app.wxss 小程序公共样式

小程序页面组成

  • js 页面逻辑(require)
  • wxml 页面结构(require)
  • wxss 页面样式
  • json 页面配置

为减少配置,描述页面4个文件必须具有相同的路径和文件名

配置

app.json为小程序全局配置

{
  //小程序页面路径
  pages: [],
  //小程序状态栏,导航,标题,窗口背景色
  window: {},
  tabBar: {},
  networkTimeout: {},
  debug: true
}

page.json为小程序页面配置,只能设置window配置项内容

{
  navigationBarBackgroundColor: '#000',
  navigationBarTextStyle: 'white',
  navigationBarTitleText: 'title',
  backgroundColor: '#fff',
  backgroundTextStyle: 'dark',
  enablePullDownRefresh: false,
  disableScroll: false,
  onReachBottomDistance: 50
}

App Service逻辑

  • 注册程序
App({
  //当小程序初始化完成
  onLaunch() {},
  //当小程序启动,或从后台进入前台显示
  onShow() {},
  //当小程序从前台进入后台
  onHide() {},
  //当小程序出错
  onError(err) {},
  //可以添加自定义函数或数据,使用this访问
  66sData:{}
});

//全局getApp()可获取小程序实例
//不要在App()内调用,App()内使用this可以拿到实例
var appInstance = getApp();
appInstance.66sData;

App()必须在app.js中注册,且只能注册一个

  • 场景值
    可在App的onLaunch和onShow中获取

  • 注册页面

Page({
  //页面初始数据
  data: { num: 0 },
  //监听页面加载
  onLoad() {},
  //监听页面初次渲染完成
  onReady() {},
  //监听页面显示
  onShow() {},
  //监听页面隐藏
  onHide() {},
  //监听页面卸载
  onUnload() {},
  //监听用户下拉刷新
  onPullDownRefresh() {},
  //监听用户上拉触底
  onReachBottom() {},
  //监听用户点分享
  onShareAppMessage() {},
  //监听页面滚动
  onPageScroll() {},
  //可以添加自定义函数或数据,使用this访问
  66sData:{},
  changeNum: function(){
    let route = this.route;
    this.setData({num: route});
  }
});

//获取当前页面路径
Page.prototype.route;
//变更data值并同步视图
Page.prototype.setDate({})
  • 路由
    小程序路由由框架管理,框架以页面栈的形式维护所有页面
路由方式 页面栈行为
初始化,打开新页 新页入栈
页重定向 当前页出栈,新页入栈
页返回 页出栈,直到目标返回页,新页入栈
Tab切换 页全部出栈,只留新Tab页
重加载 页全部出栈,只留新页
//获取当前页栈数组实例,第一个为首页,最后一个为当前页
getCurrentPages();

wx.navigateTo
<navigator open-type="navigateTo" />
wx.redirectTo
<navigator open-type="redirectTo" />
wx.navigateBack
<navigator open-type="navigateBack" />
wx.switchTab
<navigator open-type="switchTab" />
wx.reLaunch
<navigator open-type="reLaunch" />
  • 模块化
//comme.js
//通过module.export和export导出
module.export.sayHello = () => {};
export.sayGoodbye = () => {};

//通过require导入
const common = require('comm.js');
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容