【WePY小程序框架实战三】-组件传值

简介: 【WePY小程序框架实战一】-创建项目【WePY小程序框架实战二】-页面结构父子组件传值静态传值静态传值为父组件向子组件传递常量数据,因此只能传递String字符串类型。父组件 (parent.
<view>
    <child name="leinov"></child>
</view>
子组件(child.wpy)
<template lang="wxml">
    <view>
        {{name}}
    </view>
</template>

<script>

    props={
        name:String
    }
    
    onLoad(){
        console.log(this.name);//leinov
    }
     
</script>

动态传值

  • sync修饰符来达到父组件数据绑定至子组件的效果
  • 也可以通过设置子组件props的twoWay: true来达到子组件数据绑定至父组件的效果
  • 如果既使用.sync修饰符,同时子组件props中添加的twoWay: true时,就可以实现数据的双向绑定了。

异步数据父子组件传值注意

parent

<script>
  export default class Parents extends wepy.page {
    
    data = {
        tabdata:{}, //下面要用这里必须要写上
    }
    
    async onLoad() {
        
       let data =  await getData(,"public/data",{session_key:"1234456"});
       this.tabdata= data.tab;
       this.$apply();//必须
    }
  }
</script>
<template lang="wxml">
   <view class="title" slot="title"></view>
   <view class="title" slot="content">
     <Tab :tab.sync="tabdata" ></Tab>
   </view>
</template>

child

<template lang="wxml">
    <view class="title" slot="title">{{tab}}</view>
</template>
export default class Tab extends wepy.component {
      props = {
        tab:{
          type:Object,
          default:null,
          twoWay:true
        }
}

以下必须注意

  • 模版中要给子组件传的值 在data里要声明好
  • 取到异步值后要使用this.$apply()手动更新组件
  • 在父组件中调用子组件的属性名要加.sync
  • 子组件要使用父组件的props必须在props里声明
目录
相关文章
|
28天前
|
小程序 JavaScript
【微信小程序】之轮播图、swiper、swiper-item、banner组件使用
【微信小程序】之轮播图、swiper、swiper-item、banner组件使用
【微信小程序】之轮播图、swiper、swiper-item、banner组件使用
|
2月前
|
存储 小程序 JavaScript
【微信小程序】-- 表单组件 - picker 实现日期选择器(五十三)
【微信小程序】-- 表单组件 - picker 实现日期选择器(五十三)
|
2月前
|
JSON 小程序 数据格式
【微信小程序】-- 自定义组件总结 (四十)
【微信小程序】-- 自定义组件总结 (四十)
|
2月前
|
小程序 JavaScript
【微信小程序】-- 自定义组件 - behaviors(三十九)
【微信小程序】-- 自定义组件 - behaviors(三十九)
|
2月前
|
JSON 小程序 JavaScript
【微信小程序】-- 自定义组件 - 组件所在页面的生命周期 & 插槽(三十七)
【微信小程序】-- 自定义组件 - 组件所在页面的生命周期 & 插槽(三十七)
|
28天前
|
小程序 JavaScript
【微信小程序】之顶部选项卡自定义tabs(不用mp-tabs扩展组件,太难用了)
【微信小程序】之顶部选项卡自定义tabs(不用mp-tabs扩展组件,太难用了)
|
23小时前
|
开发框架 移动开发 小程序
小程序开发框架
- WePY(1.4K+ stars): 腾讯的Vue风格组件化框架 - MpVue(1.3K+ stars): 美团的Vue支持框架 - Taro(京东出品): React规范,多端开发,包括H5和RN - Tina.js: 渐进式框架,兼容MINA API,适合新手 各框架特色各异,适用于不同技能和项目需求。
12 0
|
28天前
|
小程序 JavaScript
【微信小程序】之自定义四宫格(不用mp-grids扩展组件实现,这个组件太难用了)
【微信小程序】之自定义四宫格(不用mp-grids扩展组件实现,这个组件太难用了)
|
2月前
|
小程序 JavaScript
在使用微信小程序开发中用vant2框架中的Uploader 文件上传wx.uploadFile无反应和使用多图上传
网上有的说是bind:after-read="afterRead"的命名问题不支持-,但是我这儿执行了console.log("file",file);证明函数运行了。后来发现是multiple="true"原因开启了多图上传,如果是多图上传的话file就是数组了
49 2
|
2月前
|
JSON 资源调度 小程序
一个强大的小程序富文本组件mp-html
一个强大的小程序富文本组件mp-html
31 0