小程序组件传值

1、组件、插件、类库、框架

组件:具有完整功能(html-视图,css-样式,js-逻辑),并且独立运行的模块
插件:通常是为了完成某项具体的业务功能而开发的js文件 例如:swiper.js,弹框.js,。。。。
类库:library,是提供了为了完成项目的工具方法的集合,跟具体的业务无关! 例如:jQuery,lodash.js
框架:framework,分 是为了快速完成项目搭建的基础。框架分:UI 框架和javaScript框架
   UI框架:boostStrap,Element UI,vant UI,iview,and Design.....
   javaScript框架:vue.js,React.js,Angular.js

2、小程序组件分类

(1)、内置组件:小程序内置组件,直接可以拿来用,无需安装

(2)、第三方组件:需要安装—引入—使用

推荐基于小程序的UI框架:vant UI

官方文档地址:https://vant-contrib.gitee.io/vant-weapp/#/intro
(3)、自定义组件:自己开发组件,然后再项目中多处复用,提高开发效率,这也是组件化的核心思想-
快速创建一个组件的步骤:

  1. 新建的组件构造器:
Component({

})

	2. 文件类型也有4个:wxml,json,js,wxss

3、在需要的页面xxx.json或全局app.json配置文件中引入自定义组件,例如:cate.json

{
  "usingComponents": {
    "Dialog":"/components/dialog/dialog"
  }
}

4、将Dialog显示到wxml视图上 例如:cate.wxml

 <Dialog-box />

组件之间如何通讯

小程序组件通讯实现方式

  • 第一种:父传子

    • 如何传
     <Dialog-box 
        id="dialog"
        title="订单信息"
        content="订单支付内容"
    />
    
    • 如何接
...
 properties: {
   //要接收的属性
   title:{
     //接收的类型
     type:String,
     //接收的默认值
     value:"此处应该有一个标题"
   },
   content:{
     type:String,
     value:"此处应该是内容"
   }
 },
 ....
})
  • 第二种:子传父
主要通过事件派发,监听模式
Vue:this.$emit('自定义的事件名',要传递的值)
小程序:this.triggerEvent('自定义的事件名',要传递的值,事件选项)


子派发事件:triggerEvent
 //确定逻辑
    confirm_btn() {
      //向父级派发confirm事件
      this.triggerEvent('confirm','您点击确定啦')
    },

父监听:

<Dialog-box 
      id="dialog"
      title="订单信息"
      content="订单支付内容"
      bind:confirm="myconfirm"
      bind:cancel="mycancel"
  />
  • 第三种:兄弟之间
vue兄弟组件传值:bus,vuex

小程序:主要通过利用父级组件当桥梁,来实现兄弟组件通讯

A:父组件:cate

 <A bind:A="myA"/>
 <B mynum="{{ num }}"/>
 
 
B传给C兄弟

B传A:

wxml:
<view>
 <text>我是A组件-{{ num }}</text>
 <view><button size="mini" bindtap="goToParent">把A的数据发送给B组件</button></view>
</view>

JS:
 goToParent() {
     this.triggerEvent('A',this.data.num)
   }
 }
 
 
 
A传C  
 <A bind:A="myA"/>
 
   myA(e) {
   this.setData({
     num:e.detail
   })
 }
 
C再将A接的值再接收:

//父级代码:cate
  <B mynum="{{ num }}"/>


C内部的代码:
Component({
 properties: {
   mynum:{
     type:Number,
     value:99
   }
 },
})

<view>
 <text>我是B组件--{{ mynum }}</text>
</view>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值