这篇文章我会以我本身开发经验从以下几个角度来说解相关的内容html
最经常使用,最规范的方式,设置数据监听器observer
。json
假设在页面内引入了组件sc
小程序
"usingComponents": { "sc":"" }
想要配置一个监听器用来监听页面中数据list
的变化,组件在页面中的写法以下:微信小程序
<sc list="{{list}}" > </sc>
组件中的监听器写法以下,当页面中的`list`值每次发生变化,都会触发`observer`监听器,打印出变化值。
properties: { list:{ type:Array, observer: function (newVal, oldVal){ console.log(newVal) } } }
同理,除了动态传值之外,这种方式也能够直接传入静态值,即不须要调用obeserver
监听器。在组件中能够直接使用this.properties.*
来获取properties
中的各个值(*表明各个属性值的名称)。微信
既然组件能够设置监听器用来监听页面数据变化,用来达到数据传递的效果,页面一样可使用监听器,来监听组件触发的信息传送。dom
仍然以上面的组件为例,如何向页面中传送信息?函数
在页面中配置组件监听器this
ComponentListener(e){ let info = e.detail; }
组件选择事件并绑定该监听器code
<sc bind:listener="ComponentListener" > </sc>
从组件中往页面传入输入只须要在组件中触发对应事件,e.detail
就是传过去的数据component
this.triggerEvent('listener',{func,tid});
假设咱们引入并使用了一个组件comment-bottom
,组件内有函数handleCloseInput
,须要在某个逻辑中触发。
想要使用组件内的函数,必须为组件配置一个惟一id
,这样就能够在页面中经过dom
操做选中组件并调用组件中的函数。
<comment-bottom id="commentBottom"></comment-bottom>
组件中的函数在页面中的调用逻辑以下:
this.commentBottom = this.selectComponent("#commentBottom"); this.commentBottom.handleCloseInput();
上面向页面传数据的方式,实际上就是调用了页面中的函数。咱们能够这样理解该逻辑,将该用法理解为一个函数映射。
<component bind:componentfunc="pagefun"></component>
当使用trigger
触发componentfunc
时,经过bind:
这个函数映射关系,就会触发页面中的pagefunc
。
其次,调用页面内的函数,还能够经过页面栈的方式,组件并不占用页面的栈空间,所以在组件中使用getCurrentPages
就能够得到对应页面的数据和方法。
var allpages = getCurrentPages();//获取所有页面数据 var nowpage = allpages[allpages.length - 1].data;//获取当前页面的数据。 var nowpage = allpages[allpages.length - 1];//获取页面,包括数据和方法
这部份内容出自个人一篇文章,我会把地址放在参考文件中。
结语:
组件和组件之间的数据传递和组件与页面之间并无太大区别,组件中也能够嵌套组件。
参考文件