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) =>

<Checkbox key={index} value={color}>{color}</Checkbox>)

}

</CheckboxGroup>

<View>选择尺码</View>

<CheckboxGroup onChange={value => setSpec(prev => (...prev, ...value))}>

{

...new Set(skuList.map(i =\> i.spec\[1))].map((size, index) => (

<Checkbox key={index} value={size}>{size}</Checkbox>

))

}

</CheckboxGroup>

<AtDivider />

{/* 购买数量 */}

<View>

<AtInputNumber

min={1}

max={100}

step={1}

value={num}

onChange={value => setNum(value)}

/>

</View>

<AtDivider />

{/* 确认按钮 */}

<View>

<AtButton type='primary'>确认</AtButton>

</View>

</View>

</View>

);

}

```

  1. 在 `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 <View>{children}</View>;

}

export default App;

```

这样,在 Taro.js 和 NutUI 的基础上我们已经编写了一个基本的商品选择页面。当用户选择商品规格和数量后,点击确认按钮即可触发相应的事件进行下单操作。

需要注意的是,这里使用了不少的 Taro-ui 组件,比如 `AtInputNumber`、`AtDivider` 以及 `AtButton` 等等。需要在代码中导入这些组件并声明相关使用,

若有收获,就点个赞吧

相关推荐
xxie1237943 小时前
return与print
开发语言·python
秋93 小时前
从 Python 后端工程师转型 AI Engineer(AI 工程化)的完整补课清单(2026实战版)
开发语言·人工智能·python
程序员二叉4 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结
java·开发语言·面试
慕木沐4 小时前
Google ADK Java 1.0版本 核心机制与实战 Demo
java·开发语言·python
Roann_seo%4 小时前
C++文件操作完全指南:从文本读写到二进制文件处理
开发语言·c++
huangdong_5 小时前
淘宝商品SKU图自动分类技术深度解析:从DOM解析到智能归档
开发语言·javascript·ecmascript
阿正的梦工坊5 小时前
【Rust】12-借用检查器与非词法生命周期
开发语言·后端·rust
qq_2518364576 小时前
基于java Web网络订餐系统设计与实现 源码文档
java·开发语言·前端
秋96 小时前
3年经验Python后端转AI Engineer:3个月实战转型计划(2026版)
开发语言·人工智能·python
凡人叶枫6 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法