taro.js和nutui实现商品选择页面

  1. 首先安装 Taro.js 和 NutUI:

```

npm install -g @tarojs/cli

npm install taro-ui

```

  1. 创建 Taro 项目并进入项目目录:

```

taro init myapp

cd myapp

```

  1. 选用 Taro 模板一并安装依赖:

```

npm install

```

  1. 在页面目录中创建商品选择页:

```

taro create --name goods --type page

```

  1. 在 `goods.jsx`中导入并使用 Taro-ui 组件库相关的组件:

```jsx

import Taro, { useState } from "@tarojs/taro";

import { View, Text, Image, Button, Checkbox, CheckboxGroup } from "@tarojs/components";

import { AtInputNumber, AtDivider, AtButton } from "taro-ui";

// 这里假设我们有两个规格参数,分别是颜色和尺码,定义一个数组

const skuList = [

{

id: 1,

spec: ['红色', 'L'],

price: 100,

},

{

id: 2,

spec: ['红色', 'M'],

price: 98,

},

{

id: 3,

spec: ['蓝色', 'L'],

price: 99,

},

{

id: 4,

spec: ['蓝色', 'M'],

price: 97,

},

];

export default function Goods() {

// 存储当前选择的规格,初始为空

const [spec, setSpec] = useState([]);

// 存储当前选择的数量,初始为1

const [num, setNum] = useState(1);

return (

<View>

{/* 商品信息 */}

<View>

<Image src="https://placehold.it/100" />

<Text>商品名称</Text>

<Text>商品价格</Text>

</View>

<AtDivider />

{/* 规格选择 */}

<View>

<Text>选择: {spec.join('-')}</Text>

<View>选择颜色</View>

<CheckboxGroup onChange={value => setSpec(value)}>

{

...new Set(skuList.map(i =\> i.spec\[0\]))\].map((color, index) =\> \{color}\) } \ \选择尺码\ \ setSpec(prev =\> (\[...prev, ...value\]))}\> { \[...new Set(skuList.map(i =\> i.spec\[1\]))\].map((size, index) =\> ( \{size}\ )) } \ \ {/\* 购买数量 \*/} \ \ setNum(value)} /\> \ \ {/\* 确认按钮 \*/} \ \确认\ \ \ \ ); } \`\`\` 6. 在 \`app.jsx\` 中注册并配置 Taro-ui 组件库: \`\`\`jsx import Taro from "@tarojs/taro"; import { AtButton } from "taro-ui"; import "taro-ui/dist/style/index.scss"; // 一定要引入样式 function App({ children }) { return \{children}\; } export default App; \`\`\` 这样,在 Taro.js 和 NutUI 的基础上我们已经编写了一个基本的商品选择页面。当用户选择商品规格和数量后,点击确认按钮即可触发相应的事件进行下单操作。 需要注意的是,这里使用了不少的 Taro-ui 组件,比如 \`AtInputNumber\`、\`AtDivider\` 以及 \`AtButton\` 等等。需要在代码中导入这些组件并声明相关使用, 若有收获,就点个赞吧

相关推荐
majingming1234 小时前
FUNCTION
java·前端·javascript
是娇娇公主~4 小时前
C++ 中 std::deque 的原理?它内部是如何实现的?
开发语言·c++·stl
SuperEugene5 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
子兮曰5 小时前
Bun v1.3.11 官方更新全整理:新增功能、关键修复与升级验证
javascript·node.js·bun
Setsuna_F_Seiei6 小时前
AI 对话应用之页面滚动交互的实现
前端·javascript·ai编程
xuxie996 小时前
N11 ARM-irq
java·开发语言
wefly20176 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
luanma1509807 小时前
PHP vs C++:编程语言终极对决
开发语言·c++·php
寂静or沉默7 小时前
2026最新Java岗位从P5-P7的成长面试进阶资源分享!
java·开发语言·面试
b_xinjun11207 小时前
树莓派 Ubuntu 24.04.3 LTS 安装 OpenClaw 操作说明
linux·ubuntu·arcgis