实现小程序中的自定义组件

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/st646889325/article/details/82773403

具体实现

要做自定义组件,我们先定一个小目标,比如说我们在小程序中实现一下 WEUI 中的弹窗组件,基本效果图如下。

Step1

我们初始化一个小程序(本示例基础版本库为 1.7 ),删掉里面的示例代码,并新建一个 components 文件夹,用于存放我们以后开发中的所用组件,今天我们的目的是实现一个 弹框 组件,因此,我们在 components 组件中新建一个 Dialog 文件夹来存放我们的弹窗组件,在 Dialog 下右击新建 Component 并命名为 dialog 后,会生成对应的 json wxml wxss js 4个文件,也就是一个自定义组件的组成部分,此时你的项目结构应该如下图所示:

Step2

组件初始化工作准备完成,接下来就是组件的相关配置,首先我们需要声明自定义组件,也就是

将 dialog.json 中 component 字段设为 true :

{

"component": true,

"usingComponents": {}

}

其次,我们需要在 dialog.wxml 文件中编写弹窗组件模版,在 dialog.wxss 文件中加入弹窗组件样式,dialog.wxml 文件如下:

.wx-mask {

position: fixed;

z-index: 1000;

top: 0;

right: 0;

left: 0;

bottom: 0;

background: rgba(0, 0, 0, 0.3);

}

.wx-dialog {

position: fixed;

z-index: 5000;

width: 80%;

max-width: 600rpx;

top: 50%;

left: 50%;

-webkit-transform: translate(-50%, -50%);

transform: translate(-50%, -50%);

background-color: #fff;

text-align: center;

border-radius: 3px;

overflow: hidden;

}

.wx-dialog-title {

font-size: 18px;

padding: 15px 15px 5px;

}

.wx-dialog-content {

padding: 15px 15px 5px;

min-height: 40px;

font-size: 16px;

line-height: 1.3;

word-wrap: break-word;

word-break: break-all;

color: #999;

}

.wx-dialog-footer {

display: flex;

align-items: center;

position: relative;

line-height: 45px;

font-size: 17px;

}

.wx-dialog-footer::before {

content: '';

position: absolute;

left: 0;

top: 0;

right: 0;

height: 1px;

border-top: 1px solid #d5d5d6;

color: #d5d5d6;

-webkit-transform-origin: 0 0;

transform-origin: 0 0;

-webkit-transform: scaleY(0.5);

transform: scaleY(0.5);

}

.wx-dialog-btn {

display: block;

-webkit-flex: 1;

flex: 1;

-webkit-tap-highlight-color: rgba(0, 0, 0, 0);

position: relative;

}

.wx-dialog-footer .wx-dialog-btn:nth-of-type(1) {

color: #353535;

}

.wx-dialog-footer .wx-dialog-btn:nth-of-type(2) {

color: #3cc51f;

}

.wx-dialog-footer .wx-dialog-btn:nth-of-type(2):after {

content: " ";

position: absolute;

left: 0;

top: 0;

width: 1px;

bottom: 0;

border-left: 1px solid #d5d5d6;

color: #d5d5d6;

-webkit-transform-origin: 0 0;

transform-origin: 0 0;

-webkit-transform: scaleX(0.5);

transform: scaleX(0.5);

}

step3

组件的结构和样式都有了,还缺少什么呢,没错,还缺 js , 眼睛比较犀利的同学,可能已经发现了我们在 dialog.wxml 文件中的会有一些比如 {{ isShow }} 、 {{ title }} 这样的模版变量,还定义了 _cancelEvent 和 _confirmEvent 两个方法,其具体实现就是在 dialog.js 中。

dialog.js 是自定义组件的构造器,是使用小程序中 Component 构造器生成的,调用 Component 构造器时可以用来指定自定义组件的属性、数据、方法等,具体的细节可以参考一下官方的文档

下面我通过代码注释解释一下构造器中的一些属性的使用:

Component({

options: {

multipleSlots: true // 在组件定义时的选项中启用多slot支持

},

/**

* 组件的属性列表

* 用于组件自定义设置

*/

properties: {

// 弹窗标题

title: { // 属性名

type: String, // 类型(必填),目前接受的类型包括:String, Number, Boolean, Object, Array, null(表示任意类型)

value: '标题' // 属性初始值(可选),如果未指定则会根据类型选择一个

},

// 弹窗内容

content: {

type: String,

value: '弹窗内容'

},

// 弹窗取消按钮文字

cancelText: {

type: String,

value: '取消'

},

// 弹窗确认按钮文字

confirmText: {

type: String,

value: '确定'

}

},

/**

* 私有数据,组件的初始数据

* 可用于模版渲染

*/

data: {

// 弹窗显示控制

isShow: false

},

/**

* 组件的方法列表

* 更新属性和数据的方法与更新页面数据的方法类似

*/

methods: {

/*

* 公有方法

*/

//隐藏弹框

hideDialog() {

this.setData({

isShow: !this.data.isShow

})

},

//展示弹框

showDialog() {

this.setData({

isShow: !this.data.isShow

})

},

/*

* 内部私有方法建议以下划线开头

* triggerEvent 用于触发事件

*/

_cancelEvent() {

//触发取消回调

this.triggerEvent("cancelEvent")

},

_confirmEvent() {

//触发成功回调

this.triggerEvent("confirmEvent");

}

}

})

step4

截至目前为止,你应该完成了一个自定义弹窗组件的大部分,可是你保存后并没有发现任何变化,因为我们还需要在 index.wxml 文件中引入它!

首先需要在 index.json 中引入组件:

{

"usingComponents": {

"dialog": "/components/Dialog/dialog"

}

}

然后我们在 index.wxml 中引入它,并增加我们自定义的一些值,如下

<view class="container">

<dialog id='dialog'

title='我是标题'

content='恭喜你,学会了小程序组件'

cancelText='知道了'

confirm='谢谢你'

bind:cancelEvent="_cancelEvent"

bind:confirmEvent="_confirmEvent">

</dialog>

<button type="primary" bindtap="showDialog"> ClickMe! </button>

</view>

嗯哪,还差最后一步, index.js 配置,没错,这个也很简单,我就复制粘贴了

const app = getApp()

Page({

/**

* 生命周期函数--监听页面初次渲染完成

*/

onReady: function () {

//获得dialog组件

this.dialog = this.selectComponent("#dialog");

},

showDialog() {

this.dialog.showDialog();

},

//取消事件

_cancelEvent() {

console.log('你点击了取消');

this.dialog.hideDialog();

},

//确认事件

_confirmEvent() {

console.log('你点击了确定');

this.dialog.hideDialog();

}

})

step5

让我们测试一下试试看:

点击按钮之后呢,会出现如下效果:

猜你喜欢

转载自blog.csdn.net/st646889325/article/details/82773403