• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

具体实现

要做自定义组件,我们先定一个小目标,比如说我们在小程序中实现一下 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

让我们测试一下试试看:

 

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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
微信小程序实现路线规划demo发布时间:2022-07-18
下一篇:
一个内嵌全国高校地图的小程序,走到哪导航到哪发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap