Heim >Web-Frontend >uni-app >Wie implementiert Uniapp die Funktion „Linkswischen zum Löschen von Produkten'?
Mit der Entwicklung des mobilen Internets werden E-Commerce-Apps immer beliebter und das Einkaufen immer bequemer. In einigen E-Commerce-Apps können Benutzer Produkte über die verschiebbare Oberfläche bedienen, indem sie beispielsweise nach links wischen, um Produkte zu löschen. Wie implementiert man also das Wischen nach links, um Produkte in Uniapp zu löschen? In diesem Artikel wird es Ihnen ausführlich vorgestellt.
<movable-view class="swiper-item" x="{{item.x}}" animation="true" direction="horizontal" damping="80" friction="2" ></movable-view>
wobei x die Position der Komponente der beweglichen Ansicht ist und die Einheit rpx ist. In unserer Produktliste sollte jedes Produkt eine bewegliche Ansichtskomponente sein.
<!-- 让商品列表动态渲染 --> <view v-for="(item, index) in list" :key="index"> <!-- 判断商品是否被选中,选中时改变背景颜色 --> <movable-view :class="{ 'swiper-item-active': item.active }" @change="handleChange(index, $event)" @touchend="handleTouchEnd(index, $event)" x="{{item.x}}" animation="true" direction="horizontal" damping="80" friction="2" :style="{left: item.active ? '-200rpx' : 0}" > <view class="swiper-wrapper"> <view class="image-wrapper"> <image :src="item.image"></image> </view> <view class="content-wrapper"> <view class="title">{{item.title}}</view> <view class="price">{{item.price}}</view> <view class="number">{{item.number}}</view> </view> <!-- 绑定删除操作 --> <view class="delete-btn" v-if="item.active" @click="$emit('delete', index)" >删除</view> </view> </movable-view> </view> <script> export default { data() { return { list: [ { title: '商品1', image: '', price: 100, number: 1, active: false, x: 0 }, { title: '商品2', image: '', price: 200, number: 1, active: false, x: 0 } ] } }, methods: { // 左滑删除商品 handleChange(index, event) { // 获取movable-view组件的位置信息 const { detail } = event; const x = detail.x; this.list[index].x = x; // 当移动距离超过200rpx时,显示删除按钮 if (x <= -200) { this.list[index].active = true; } else { this.list[index].active = false; } }, // 停止触摸事件 handleTouchEnd(index, event) { const { detail } = event; const x = detail.x; // 当用户放手时,如果movable-view组件位置小于-200rpx,则直接删除该商品 if (x <= -200) { this.list.splice(index, 1); } else { // 否则,商品位置复位 this.list[index].x = 0; } // 删除操作完成后,将所有商品的选中状态重置 this.list.forEach((item) => { item.active = false; }); } } } </script>
Mit dem obigen Beispielcode können wir die Funktion „Nach links wischen zum Löschen eines Produkts“ in Uniapp implementieren. Es ist zu beachten, dass die Produktliste hier nur ein Beispiel ist. In tatsächlichen Situationen müssen wir die Produktliste von der API abrufen und dynamisch rendern. Gleichzeitig müssen wir den Löschvorgang auch in einen asynchronen Vorgang umwandeln, d. h. beim Löschen eines Elements müssen wir eine Anfrage an den Server senden. Hier stellen wir nur die Grundoperationen in Uniapp vor, und die spezifische Implementierung muss weiter verbessert werden.
Das obige ist der detaillierte Inhalt vonWie implementiert Uniapp die Funktion „Linkswischen zum Löschen von Produkten'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!