codecamp

BUI 发布订阅

订阅发布模式定义了一种一对多的依赖关系,让多个订阅者对象同时监听某一个主题对象。这个主题对象在自身状态变化时,会通知所有订阅者对象,使它们能够自动更新自己的状态。

全局订阅

  // dom初始化完毕就可以执行
  bui.on("pagereadybefore",function(){


  })
  // 页面准备完毕后触发
  bui.on("pageready",function(){
    // 不管是web,还是native 最终都会触发 pageready 事件.
  })

路由订阅

全局事件

具体查看 bui.router API
js
// 监听后退事件,只要触发了后退, 不管通过按钮触发,还是通过物理后退
router.on("back",function(e){
// 执行
// e.target 跳转后的页面
// e.prevTarget 跳转前的页面
})
// 每次跳转完成以后执行
router.on("complete", function(e) {
// 执行
// e.target 跳转后的页面
// e.prevTarget 跳转前的页面
})

控件订阅

例子1: 用得最多的Tab选项卡.

  // 初始化一个控件
  var tab = bui.tab({
    id: "#id"
  })


  // tab有多种切换选项卡的方式, 所以只能在这里监听, 比方点击可以切换, 滑动可以切换, 直接调用to也可以触发.
  tab.on("to",function(){
    var index = this.index();
    console.log(index);
  })


  // 执行就会触发一次
  tab.to(0)

例子2:

  // 初始化一个控件
  var dialog = bui.dialog({
    id: "#id"
  })


  // 监听打开事件, 对话框默认是隐藏的, 隐藏的dom,在zepto.js 里面是拿不到宽高的,
  // 如果对话框里面有一些用到计算的地方, 应该监听该实例打开以后才做控件初始化或计算.
  dialog.on("open",function(){
    // 对话框打开后才执行
  })


  // 监听关闭事件
  dialog.on("close",function(){
    // 对话框关闭后执行
  })

组件发布订阅

单页面上的组件通讯, 可以通过全局的 loader.on loader.trigger 等方法.

初始化

页面组件加载了搜索组件跟列表组件

<component name="page/search/index"></component>
<component name="page/list/index"></component>

搜索组件: page/search/index.js

loader.define(["page/list/index"], function(list,require,export,module){
    // 组件从上到下执行, on的监听必须在前面, 搜索组件监听了列表组件的点击事件,
    loader.on("clickid",function(e){
        // 传过来的参数
        console.log(e);
    })
})

列表组件: page/list/index.js

loader.define(function(require,export,module){




    $("#id").click(function(e){
      // 触发了click事件, 搜索组件那边会拿到对应的参数做相应处理.
      loader.trigger("clickid",e);
    })


})

自定义全局订阅

自定义的命名应该避免跟默认已有的冲突, 必须在trigger触发前先进行注册
js
// 在页面监听
bui.on("page-list-refresh",function(e){
console.log(e)
// 传过去的参数
})

js
// 在页面监听
bui.trigger("page-list-refresh","传过去的参数")

例子: 假如进入列表需要权限, 进入列表就通过 bui.page 插入了一个登录页, 登录页点击校验通过就要触发关闭, 我们知道可以通过 bui.history.getPageDialog(module.id) 来获取到对话框进行关闭操作, 这种是在登录页的处理. 还有一些业务类, 之间交互比较复杂, 登录页需要不断的require之前的模块进行操作, 我们可以尝试另外一种方式. 登录只做登录该做的事.

列表页: pages/list/index.js

var uipage = bui.page({
  url:"pages/login/index.html"
})


// 如果登录成功,
bui.on("loginsuccess",function(user){
  // 关闭掉对话框
  uipage.close();


  // 并且在这个模块可以方便的拿到当前模块相关信息处理.
})

登录页: pages/login/index.js



$("#login").click(function(){
  // 校验帐号密码
  var user = {
    name: "",
    password: ""
  };
  // 请求去校验帐号密码, 正确就返回true
  if( check(user) ){
    bui.ajax({
      url: "http://api/login",
      success: function(){
        // 告诉那些订阅过 loginsuccess 的操作, 可以执行了, 并把用户信息传了过去.
        bui.trigger("loginsuccess",user)
      }
    })
  }
})

BUI 插件拓展
BUI 数据驱动介绍
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

BUI 链接

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }