微信小程序Dom事件实现

面对微信小程序,可能没有像我们平时使用JQuery那样随心所欲。本篇就是为了解决这个问题。

请合理使用工具!

 

细节就不说了,直接备份一个实现的案例:

wxml

<view class="guess" >
  <view>
    <image data-data_auto = "{{ac[index]}}" data-index="{{index}}" data-num="1"  data-id="{{item.a_team_id}}" bindtap="{{item.bet==true?'chooseMe':'none'}}" mode="widthFix"  src="{{ ac[index] === 1 ?'../images/sheng0.png':'../images/sheng2.png'}}" class="img"></image>
  </view>
  <view>
    <image data-data_auto = "{{ac[index]}}" data-index="{{index}}" data-num="0" data-id="0" bindtap="{{item.bet==true?'chooseMe':'none'}}" mode="widthFix"  src="{{ ac[index] === 0 ?'../images/ping0.png':'../images/ping2.png'}}" class="img"></image>
  </view>
  <view>
    <image data-data_auto = "{{ac[index]}}" data-index="{{index}}" data-num="2" data-id="{{item.b_team_id}}" bindtap="{{item.bet==true?'chooseMe':'none'}}" mode="widthFix"  src="{{ ac[index] === 2 ?'../images/sheng0.png':'../images/sheng2.png'}}" class="img"></image>
  </view>
</view>

wxs:

//设置WXML的数据
that.setData({
  eventArray: res.data.data.data,
  active_bet: res.data.data.active_bet,
    ac:setActive(res.data.data.data)
});

//重要:创建新DOM绑定数据
function setActive($data) {
    let new_data = [];
    for(let i = 0;i<$data.length;i++){
        new_data[i] = 1;
    }
    that.ac = new_data;
    return new_data;
}

Event:

//事件解发
chooseMe(e) {
    console.log(this.ac);
  let keys = e.target.dataset.index;
  this.ac[keys] = parseInt(e.target.dataset.num);
},

  

基本原理就是:自定义DOM

转载于:https://www.cnblogs.com/q1104460935/p/9158790.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序的Canvas组件可以绘制图片、文字和形状,并支持将绘制结果保存为图片。因此,可以使用Canvas组件将需要保存的DOM元素绘制到画布上,然后将画布保存为图片。下面是实现的具体步骤: 1. 在wxml文件中,添加一个Canvas组件,设置宽高和id: ``` <canvas canvas-id="myCanvas" style="width: 100%; height: 100%;"></canvas> ``` 2. 在js文件中,获取需要保存的DOM元素,将其绘制到Canvas上: ``` // 获取需要保存的DOM元素 const query = wx.createSelectorQuery() query.select('#my-dom').boundingClientRect() query.exec(res => { // 将DOM元素绘制到Canvas上 const canvasCtx = wx.createCanvasContext('myCanvas') const width = res[0].width const height = res[0].height canvasCtx.drawImage('#my-dom', 0, 0, width, height) canvasCtx.draw(false, () => { // 保存Canvas为图片 wx.canvasToTempFilePath({ canvasId: 'myCanvas', success(res) { console.log(res.tempFilePath) } }) }) }) ``` 其中,`wx.createSelectorQuery()`用于获取DOM元素的尺寸,`wx.createCanvasContext()`用于创建Canvas上下文,`canvasCtx.drawImage()`用于将DOM元素绘制到Canvas上,`canvasCtx.draw()`用于将Canvas上的绘制结果显示出来,`wx.canvasToTempFilePath()`用于将Canvas保存为图片。 3. 在wxml文件中,将需要保存的DOM元素添加id: ``` <view id="my-dom">这是要保存的DOM元素</view> ``` 通过以上步骤,即可将需要保存的DOM元素绘制到Canvas上,并将Canvas保存为图片。需要注意的是,Canvas的绘制和保存都是异步操作,因此需要使用回调函数来处理结果。同时,由于涉及到Canvas的操作,因此需要在小程序的app.json文件中声明Canvas组件的权限: ``` "permission": { "scope.userLocation": { "desc": "你的位置信息将用于小程序定位" }, "scope.record": { "desc": "你的录音功能将用于小程序录音" }, "scope.writePhotosAlbum": { "desc": "你的相册将用于小程序保存图片" }, "scope.camera": { "desc": "你的相机将用于小程序拍照" }, "scope.userInfo": { "desc": "你的用户信息将用于小程序登录" }, "scope.invoiceTitle": { "desc": "你的发票抬头将用于小程序申请发票" }, "scope.invoice": { "desc": "你的发票信息将用于小程序申请发票" }, "scope.werun": { "desc": "你的微信运动数据将用于小程序计步" }, "scope.writePhotosAlbum": { "desc": "你的相册将用于小程序保存图片" }, "scope.camera": { "desc": "你的相机将用于小程序拍照" }, "scope.record": { "desc": "你的录音功能将用于小程序录音" }, "scope.userLocationBackground": { "desc": "你的位置信息将在后台持续更新" }, "scope.album": { "desc": "你的相册将用于小程序保存图片" }, "scope.address": { "desc": "你的收货地址将用于小程序购物" }, "scope.invoice": { "desc": "你的发票信息将用于小程序申请发票" }, "scope.camera": { "desc": "你的相机将用于小程序拍照" }, "scope.userInfo": { "desc": "你的用户信息将用于小程序登录" }, "scope.userLocation": { "desc": "你的位置信息将用于小程序定位" }, "scope.record": { "desc": "你的录音功能将用于小程序录音" }, "scope.writePhotosAlbum": { "desc": "你的相册将用于小程序保存图片" }, "scope.camera": { "desc": "你的相机将用于小程序拍照" }, "scope.userLocationBackground": { "desc": "你的位置信息将在后台持续更新" } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值