首先我们建一个跟pages同级的一个文件夹components,customer就是我们要写的组件,其目录结构如下:
wxml代码如下:
wxss代码如下:
.customer {
position: fixed;
z-index: 1000;
width:200rpx;
height: 200rpx;
}
.btn {
width: 80rpx;
height: 80rpx;
border-radius: 40rpx;
padding: 0;
opacity: 0.8;
background-image: url();
background-repeat: no-repeat;
background-size: cover;
}
.btn1 {
margin-top: 20rpx;
width: 80rpx;
height: 80rpx;
border-radius: 40rpx;
padding: 0;
opacity: 0.8;
background-image: url();
background-repeat: no-repeat;
background-size: cover;
}
.btn::after {
border: none;
}
js代码如下:
Component({
/**
* 组件的属性列表
*/
properties: {
},
/**
* 组件的初始数据
*/
data: {
top: 800,
left: 570,
},
/**
* 组件的方法列表
*/
methods: {
//组件实现拖动效果
setTouchMove: function (e) {
var that = this
if (e.touches[0].clientX < (wx.getSystemInfoSync().windowWidth - 80) && e.touches[0].clientX > 0 && e.touches[0].clientY < (wx.getSystemInfoSync().windowHeight - 120) && e.touches[0].clientY > 0) {
wx.getSystemInfo({
success: function (res) {
let X = (e.touches[0].clientX * (750 / res.windowWidth));
// 将高度乘以换算后的该设备的rpx与px的比例
let Y = (e.touches[0].clientY * (750 / res.windowWidth));
// 将高度乘以换算后的该设备的rpx与px的比例
that.setData({
left: X,
top: Y
})
}
})
}
},
// 拨打电话组件
phone() {
wx.makePhoneCall({
phoneNumber: this.properties.newPhone,
success: function () {
console.log("拨打电话成功!")
},
fail: function () {
console.log("拨打电话失败!")
}
})
}
},
lifetimes: {
attached() {
// 在组件实例进入页面节点树时执行
},
detached() {
// 在组件实例被从页面节点树移除时执行
},
created() {
}
}
})
至此,组件我们已经写完了,接下来要做的就是在页面引入我们所写的组件。
我们先在要引组件的页面json文件里添加一下组件路径:
{
"usingComponents": {
"customer": "/components/customer/customer"
}
}
然后在要引组件的页面wxml文件里加入这一行代码:
注意:这里的标签名要与json文件里定义的名字一致
到了这一步,我们已经大功告成了。页面效果如下所示:
组件可以实现自由拖动,涉及个人隐私,页面内容打了马赛克。