小程序父子组件通信及样式冲突

小程序组件创建

在components文件夹下创建组件 例如 : 如下

使用方式(全局)

在app.json "usingComponents": { "对应组件名": "对应的组件" }, 进行相关配置 在全局就可以使用

使用方式(局部)

上面的方式是全局注册类似于vue项目中 在main.js中 通过vue.component('组件名','组件') 的注册方法

局部的话在需要使用的界面的json中进行注册 和上面的方式一样

例子:

修改子组件的样式

在vue中使用element-ui 或者使用vant 或者是使用其他第三方的组件库 在对组件库的样式出现不满意的情况都会考虑覆盖修改 一般使用 scss就会使用 ::v-deep 或者 :deep() 但是在小程序中没有

小程序样式修改的方式

在子组件中需要通过

js 复制代码
// components/navigation-bar/navigation-bar.js
// 组件 的使用 局部注册 在json => usingComponent:{ }
Component({
  // 小程序支持外界的样式 
  // 组件 允许外界来定制类  将对应的类暴露出去 
  externalClasses: ['custom-class', 'title-class',]
  // 需要通过这样的方式将对应的样式暴露出去
  }
})

在父组件需要

wxml 复制代码
<navigation-bar back custom-class="custom-class"/>
<!-- 暴露出来的类 就是对应的属性 直接赋值父组件的类就ok 类名完全可以随便写 -->
wxss 复制代码
.custom-class {
  color:aqua
}

组件的通信(父传子)

与vue中的使用大致相同 , 但有一点不同的是 我如果直接传过去一个属性 这个属性没有值 默认是Boolean值并且为true

组件的通信(子向父)

父组件定义数据<navigation-bar count="{{count}}" back custom-class="custom-class" /> 子组件接收数据 使用properties

js 复制代码
// components/navigation-bar/navigation-bar.js
// 组件 的使用 局部注册 在json => usingComponent:{ }
Component({
  // 小程序支持外界的样式 
  // 组件 允许外界来定制类  将对应的类暴露出去 
  externalClasses: ['custom-class', 'title-class',],
  /**
   * 组件的属性列表
   */
  options: {
    multipleSlots: true
  },
  properties: {
    // back: Boolean
    // 小程序中子组件 收父组件的数据 默认值使用value属性来声明 不是vue的default
    back: {
      type: Boolean,
      value: false
    },
    count: {
    type:Number,
    value:0
    },
    // 在小程序中接受数据 需要通过 value当默认值 在vue中使用的是default 这个地方要注意
    value: Number,
  },


})

修改数据使用的是this.triggerEvent('父组件绑定的事件名',传过去的值) 这一点在vue中使用的是this.emit() 用法是一模一样的

js 复制代码
// 子组件事件传值
decrement() {
      this.triggerEvent("update-count", this.properties.count - 1)
    },
wxml 复制代码
<navigation-bar bind:update-count="updatecount" count="{{count}}" back custom-class="custom-class" />
// 父组件接受
js 复制代码
 updatecount(e) {
    console.log(e.detail);
    this.setData({
      count: e.detail
    })
  },
  // 进行修改
相关推荐
浪遏1 小时前
NestJs👈 | 前端spring🤔| 项目创建与项目结构解析
前端·javascript·后端
我命由我123452 小时前
前端性能优化指标 - DCL(触发时机、脚本对 DCL 的影响、CSS 对 DCL 的影响)
开发语言·前端·javascript·css·性能优化·html·js
轻口味3 小时前
Vue.js 什么是 Vuex?
前端·javascript·vue.js
LCG元3 小时前
Vue.js组件开发-实现全屏平滑移动、自适应图片全屏滑动切换
前端·javascript·vue.js
杯面的汤4 小时前
Vue3 Openlayers 教程(一)Openlayers 简介与如何使用 Openlayers 地图 加载一副基本的 OSM地图
前端·vue.js
我的青春不太冷4 小时前
深入探讨:服务器如何响应前端请求及后端如何查看前端提交的数据
运维·服务器·前端
16年上任的CTO4 小时前
一文大白话讲清楚webpack进阶——8——Module Federation
前端·webpack·node.js·模块联邦·federation
&白帝&5 小时前
在 Vue 3 中,怎么管理环境变量
前端·javascript·vue.js
橘猫0.o6 小时前
【C语言】static关键字的三种用法
c语言·前端·javascript
我命由我123456 小时前
Tailwind CSS - Tailwind CSS 引入(安装、初始化、配置、引入、构建、使用 Tailwind CSS)
前端·javascript·css·npm·node.js·js