微信小程序学习(二)

WXML 与 WXSS 基础https://blog.csdn.net/qq_38060125/article/details/149577716

📝 练习任务

  1. 创建一个商品列表页面,使用 wx:for 渲染商品名称与价格
  2. 添加一个"加入购物车"按钮,点击后将商品添加到 data 中的购物车数组
  3. 实现点击删除商品功能
  4. 使用 wx:if 控制当购物车为空时显示"购物车为空"

🔁 拓展建议

  • 尝试使用 hidden 属性实现与 wx:if 类似的显示控制,理解两者区别(wx:if 不渲染 DOM,hidden 通过样式控制)
  • 使用 setData 修改数据,观察页面是否自动更新
  • 尝试使用 wx:for 嵌套结构实现更复杂的页面布局(如分类商品列表)

做法:

1.修改页面:

主要是保留了原本的,只是替换了文字和绑定的函数。然后增加了购物车。暂且不做美化。

html 复制代码
<view wx:for="{{cart}}" wx:key="id" wx:for-index="idx">
  <view>
    <text>{{item.name}} - {{item.price}}元</text>
    <button bind:tap="addItem" data-index="{{idx}}">加入购物车</button>
  </view>
</view>

<view>
  <text>购物车</text>
  <!-- 使用 wx:if 判断购物车是否为空 -->
  <view wx:if="{{shoppingcart.length === 0}}">
    <text>购物车为空</text>
  </view>
  <view wx:else>
    <view wx:for="{{shoppingcart}}" wx:key="id" wx:for-index="idx">
      <text>{{item.name}} - {{item.price}}元</text>
      <button bind:tap="removeItem" data-index="{{idx}}">移除购物车</button>
    </view>
  </view>
</view>

效果如图:

2.修改逻辑部分:

cpp 复制代码
Page({
  data: {
    cart: [
      { id: 1, name: '奥特曼', price: 99 },
      { id: 2, name: '铠甲勇士', price: 50 },
      { id: 3, name: '假面骑士', price: 44 }
    ],
    shoppingcart:[]
  },
  removeItem(e) {
    const index = e.currentTarget.dataset.index; // 获取点击商品的索引
    const newShoppingCart = this.data.shoppingcart.filter((_, i) => i !== index); // 根据索引过滤商品
    this.setData({ shoppingcart: newShoppingCart }); // 更新购物车数据
    console.log('移除后的购物车:', newShoppingCart);
  },
  addItem(e)
  {
    const index = e.currentTarget.dataset.index; // 获取当前点击的商品索引
    const selectedItem = this.data.cart[index]; // 根据索引取出商品
    const shoppingcart = this.data.shoppingcart;
    shoppingcart.push(selectedItem); 
    this.setData({
      shoppingcart // 更新购物车数据
    });
    console.log('商品已加入购物车:', selectedItem);
  }
})

效果:

可以正常的增加和删除。

拓展:

使用 hidden 替代 wx:if 控制购物车状态显示

原理对比:
  • wx:if
    • 元素被销毁和重新渲染。
    • 性能更高,适用于页面内容切换不频繁的场景。
  • hidden
    • 元素通过样式 display: none 隐藏,但不会被销毁。
    • 性能更差,但适用于页面内容切换频繁的场景。
使用 hidden 替代 wx:if
html 复制代码
<!-- 使用 hidden 属性 -->
<view>
  <text hidden="{{shoppingcart.length > 0}}">购物车为空</text>
  <view hidden="{{shoppingcart.length === 0}}">
    <view wx:for="{{shoppingcart}}" wx:key="id" wx:for-index="idx">
      <text>{{item.name}} - ¥{{item.price}}</text>
      <button bindtap="removeItem" data-index="{{idx}}">移除</button>
    </view>
  </view>
</view>
相关推荐
ZeroNews内网穿透2 小时前
新版发布!“零讯”微信小程序版本更新
运维·服务器·网络·python·安全·微信小程序·小程序
molong9312 小时前
Android 应用配置跳转微信小程序
android·微信小程序·小程序
杏花春雨江南2 小时前
微信小程序里 uni.navigateTo 用的多了, 容易报错,
微信小程序·小程序·notepad++
2501_915106322 小时前
iOS 可分发是已经上架了吗?深入解析应用分发状态、ipa 文件上传、TestFlight 测试与 App Store 审核流程
android·ios·小程序·https·uni-app·iphone·webview
2501_9160074711 小时前
HTTPS 抓包乱码怎么办?原因剖析、排查步骤与实战工具对策(HTTPS 抓包乱码、gzipbrotli、TLS 解密、iOS 抓包)
android·ios·小程序·https·uni-app·iphone·webview
Coovally AI模型快速验证12 小时前
从避障到实时建图:机器学习如何让无人机更智能、更安全、更实用(附微型机载演示示例)
人工智能·深度学习·神经网络·学习·安全·机器学习·无人机
卷Java12 小时前
CSS模板语法修复总结
java·前端·css·数据库·微信小程序·uni-app·springboot
东木君_12 小时前
RK3588:MIPI底层驱动学习——入门第三篇(IIC与V4L2如何共存?)
学习
say_fall12 小时前
C语言底层学习(2.指针与数组的关系与应用)(超详细)
c语言·开发语言·学习