Bug

* Bug 表现是什么?预期表现是什么?

this.setData更新movable-view数据,movable-view组件位置重置(并没有修改x,y值);预期表示是this.setData更新movable-view数据,组件的位置不会改变

* 如何复现?

.wxml

<movable-area style="height: 1000rpx; width: 100%; background: red;" scale-area>

<block wx:for="{{imgsk}}" wx:key>

<movable-view style="width:{{item.width}};height:{{item.height}};background:{{item.bgcolor}};"x="{{item.x}}" y="{{item.y}}" direction="all"  damping="99999999999" data-ind="{{item.ind}}">

movable-view>

block>

movable-area>

<view style="width:120rpx;height:60rpx;background:yellow" catchtap="more">

<text>点我text>

view>


.js

Page({

data:{

imgsk: [

{

img_src: '/images/yizi.png',

x: 200,

y: 120,

width: '80rpx',

height: '80rpx',

bgcolor: 'blue'

},

{

img_src: '/images/yizi.png',

x: 100,

y: 400,

width: '80rpx',

height: '80rpx',

bgcolor: 'green'

}

]

},

more:function(){

// var inde = this.data.imgsk.length

// this.data.imgsk.push({

//   img_src: '/images/yizi.png',

//   x: 10,

//   y: 10,

//   width: '80rpx',

//   height: '80rpx',

//   bgcolor: 'black'

// });

var imgskc = this.data.imgsk;

this.setData({

imgsk: imgskc

});

}


})




* 解决方式


修改.wxml为以下代码

<movable-area style="height: 1000rpx; width: 100%; background: red;" scale-area>

<block wx:for="{{imgsk}}" wx:key>

<movable-view style="width:{{item.width}};height:{{item.height}};background:{{item.bgcolor}};transform: translateX({{item.x+'px'}}) translateY({{item.y+'px'}}) translateZ(0px) scale(1); transform-origin: center center 0px;"x="{{item.x}}" y="{{item.y}}" direction="all"  damping="99999999999" data-ind="{{item.ind}}">

movable-view>

block>

movable-area>

<view style="width:120rpx;height:60rpx;background:yellow" catchtap="

展开全部
收起
1回答
提交回答
  • 至过去的我

    2044人对此回答表示赞同

    我是未来的你,你现在是不是在年找寻小程序答案。你不要感觉诧异,给你来信原因,就是让你不在后悔。今天去学习如何推广小程序,相信......点击查看更多>
    发布于
  • Roberto一帆

    18人对此回答表示赞同

    今天仔细看了setData前后,WXML前后的差别,发现movable-view实际上位置是通过transform:translateX(100px)translateY(400px)translateZ(0px)scale(1);transform-origin:centercenter0px;这么一句话来控制的,因此在模板中我添加了这样的一句话,于是位置信息不会重置。具体代码见解决方案。

    展开
    18
    0回复
    发布于 5年前

    评论(0)

    收起评论

A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
咨询热线

13312967497

扫码添加业务即可随时咨询 还可领取小程序推广攻略

业务咨询: 13312967497
扫码咨询

扫码咨询套餐

回到顶部