目录
小程序是一个易上手的东西, 对于新手来说,多看官方文档,可以初步做出比较完整的小程序,正是因为简单上手,功能实现简单,小程序是越来越火,商业价值也越来越大。本文我们将教大家一种微信小程序-仿盒马鲜生。
项目初览
项目功能
小程序设计过程
1.项目工具和文档
2.项目开发
3.项目发布
部分功能解析
1.首页轮播图
2.分类商品管理
3.购物车操作
4.weui框架引入
总结
项目地址:
个人简介
首页 微信小程序 小程序开发 微信小程序-仿盒马鲜生

微信小程序-仿盒马鲜生

Dec 05, 2017 pm 04:39 PM
小程序 程序

小程序是一个易上手的东西, 对于新手来说,多看官方文档,可以初步做出比较完整的小程序,正是因为简单上手,功能实现简单,小程序是越来越火,商业价值也越来越大。本文我们将教大家一种微信小程序-仿盒马鲜生。

项目初览

盒马鲜生是阿里巴巴对线下超市完全重构的新零售业态,热度十分。

微信小程序-仿盒马鲜生

微信小程序-仿盒马鲜生

微信小程序-仿盒马鲜生

微信小程序-仿盒马鲜生
微信小程序-仿盒马鲜生

项目功能

1

2

3

4

5

* 用户信息注册

* 首页几个轮播和界面交互

* 分类商品管理购买

* 购物车界面交互及其操作

* 个人信息界面

登录后复制
登录后复制

小程序设计过程

小程序是一个易上手的东西, 对于新手来说,多看官方文档,可以初步做出比较完整的小程序,正是因为简单上手,功能实现简单,小程序是越来越火,商业价值也越来越大。

1.项目工具和文档

  1. 微信web开发者工具:微信小程序官网  这是个比较好用的编辑器,对于小程序编辑很方便。

  2. 开发文档:微信小程序宝典秘籍 通过这个查找微信小程序的API,组件,框架等等。

  3. 图标库: Iconfont-阿里巴巴矢量图标库 这个可以找到自己想要的几乎所有的小图标,十分方便。

  4. Easy Mork: easy-mock 用于后台的模拟,得到JSON数据;

  5. weui框架引入, 例如个人信息界面,用weui可以很快很方便的做

2.项目开发

微信小程序开发和传统的H5开发还是有些不同的, 容易踩坑。
小程序是基于MVVM的的框架,合理利用数据绑定实现界面的更新是很关键的
开发时不要一股脑的写写写,多看看文档,你会发现你不小心原生写了个组件。。

3.项目发布

进入开发平台,注册项目信息->在编辑器中上传版本->在开发版本中选择提交审核->审核通过->项目上线

部分功能解析

先看看我的项目目录

1

2

3

4

5

6

7

8

    "pages": [

     "pages/index/index",  //主界面

      "pages/person/person"//个人界面

     "pages/classify/classify"//分类商品界面

     "pages/class/myFruits/myFruits"//水果商店

     "pages/class/myMeat/myMeat"//肉类食品商店

     "pages/myCart/myCart"    //购物车

     ],

登录后复制
登录后复制

1.首页轮播图

轮播有几种形式, 比如常见的横向海报图片展示, 还有横纵向商品列表展示,头条信息框轮换
siwper组件很好的实现了横向海报图片展示,比如

1

2

3

4

5

6

7

        <swiper indicator-dots="{{indicatorDots}}" autoplay="{{autoplay}}" interval="{{interval}}" duration="{{duration}}">

            <block wx:for="{{imgUrls}}" wx:key="index">

                <swiper-item>

                    <image src="{{item}}" class="slide-image"  />

                </swiper-item>

            </block>

        </swiper>

登录后复制
登录后复制

然而横向滑动需要注意些别的细节  
首先要给swiper组件加上scroll-x-="true"  
然后给轮播的子元素父容器设置display: inline-block; white-space: nowrap;

头条信息框转换采用上下轮换, 使用scroll-view嵌套swiper完成

1

2

3

4

5

6

7

    <scroll-view scroll-y-="true"  >

                <swiper autoplay="{{autoplay}}" interval="{{interval1}}" duration="{{duration}}" vertical="true">

                    <block wx:for="{{something}}" wx:key="index">

                         //内容 

                    </block>

                </swiper>

    </scroll-view>

登录后复制
登录后复制

2.分类商品管理

首先在index界面通过onLoad生命周期函数 ,
通过easy-moc获取后台数据,将必要的信息送给全局的globalData

1

2

3

4

5

6

wx.request({

      url: 'http://www.easy-mock.com/mock/5a1ffb42583969285ab22bb7/orderOnline/orderOnline',

      complete: res => {

        this.globalData.classifyList = res.data;

      },

    })

登录后复制
登录后复制

对于数据处理,需要理清哪些是全局信息, 哪些是局部信息
比如所有商品的信息,购物车里的商品,就得放到全局中 ,而有些比如当前界面的状态,一般放到当前界面的Data里面保存

而有些个人信息,比如出生年月,账号信息   则可以通过wx.setStorage 和wx.getStorage放入本地存储

3.购物车操作

购物车中的操作无非是些加加减减,需要自己不断调试,找出哪里不合常理
通过view,button里的bindtap等操作,实现对商品信息的修改,购物车状态的处理

举个例子  减少购物车中的商品的数量操作

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

reduceItems: function (e) {

    let carts = app.globalData.carts;    //获取购物车的信息

    let classifyList = app.globalData.classifyList;  //获取商品的信息

    for (let key of carts) {                        //遍历购物车数组

      if (key.id === e.target.dataset.id) {         //通过WXML中 view里面的bind-id传过来的参数进行查找

        key.cartSelected = true;

        if (key.num === 1) {                  //如果数量为1还要减

          key.num--;

          key.cartSelected = false;           //购物车不选中

          key.selected = false;               //商品中不选中

          app.globalData.carts = carts.filter((item) => {    //进行购物车中商品剔除

            return item.id != e.target.dataset.id;

          })

        else {

          key.num--;

        }

      }

    }

    let num = 0;                                 //实时更新购物车小计界面显示

    let totalPrice = 0;

    for (let key of carts) {

      if (key.cartSelected) {

        num += key.num;

        totalPrice += key.num * key.price;

      }

    }

    this.setData({                          //通过setData进行当前页面Data数据管理

      cart: app.globalData.carts,

      cartTotal: num,

      cartTotalPrice: totalPrice,

    })

  },

登录后复制
登录后复制

4.weui框架引入

在全局CSS样式中 添加的CSS适配于所有的页面,由此可以引入weui ,做一些界面真的很方便

1

@import './styles/weui.wxss';

登录后复制
登录后复制

总结

  1. 微信小程序的组件,API很强大,需要不断的探索,不断的学习,多看文档

  2. 善于利用有效资源, 比如iconfont  esay-moc weui等

  3. 切页面要细心,善于利用弹性布局等布局方法,小程序的rpx确实很好用

  4. 不要一股脑的写代码, 当函数具有复用性,应该抽象出来,封装好,这样代码才易于维护,易读

项目地址:

https://github.com/fishman17/...   内含详细注释

个人简介

github : https://github.com/fishman17
邮箱 : 734583898@qq.com

最后 如果您喜欢这个项目的话,给个star哦 谢谢!


项目初览

仿造盒马鲜生,实现了部分功能。


盒马鲜生是阿里巴巴对线下超市完全重构的新零售业态,热度十分

微信小程序-仿盒马鲜生

微信小程序-仿盒马鲜生

微信小程序-仿盒马鲜生

微信小程序-仿盒马鲜生
微信小程序-仿盒马鲜生

项目功能

1

2

3

4

5

* 用户信息注册

* 首页几个轮播和界面交互

* 分类商品管理购买

* 购物车界面交互及其操作

* 个人信息界面

登录后复制
登录后复制

小程序设计过程

小程序是一个易上手的东西, 对于新手来说,多看官方文档,可以初步做出比较完整的小程序,正是因为简单上手,功能实现简单,小程序是越来越火,商业价值也越来越大。

1.项目工具和文档

  1. 微信web开发者工具:微信小程序官网  这是个比较好用的编辑器,对于小程序编辑很方便。

  2. 开发文档:微信小程序宝典秘籍 通过这个查找微信小程序的API,组件,框架等等。

  3. 图标库: Iconfont-阿里巴巴矢量图标库 这个可以找到自己想要的几乎所有的小图标,十分方便。

  4. Easy Mork: easy-mock 用于后台的模拟,得到JSON数据;

  5. weui框架引入, 例如个人信息界面,用weui可以很快很方便的做

2.项目开发

微信小程序开发和传统的H5开发还是有些不同的, 容易踩坑。
小程序是基于MVVM的的框架,合理利用数据绑定实现界面的更新是很关键的
开发时不要一股脑的写写写,多看看文档,你会发现你不小心原生写了个组件。。

3.项目发布

进入开发平台,注册项目信息->在编辑器中上传版本->在开发版本中选择提交审核->审核通过->项目上线

部分功能解析

先看看我的项目目录

1

2

3

4

5

6

7

8

    "pages": [

     "pages/index/index",  //主界面

      "pages/person/person"//个人界面

     "pages/classify/classify"//分类商品界面

     "pages/class/myFruits/myFruits"//水果商店

     "pages/class/myMeat/myMeat"//肉类食品商店

     "pages/myCart/myCart"    //购物车

     ],

登录后复制
登录后复制

1.首页轮播图

轮播有几种形式, 比如常见的横向海报图片展示, 还有横纵向商品列表展示,头条信息框轮换
siwper组件很好的实现了横向海报图片展示,比如

1

2

3

4

5

6

7

        <swiper indicator-dots="{{indicatorDots}}" autoplay="{{autoplay}}" interval="{{interval}}" duration="{{duration}}">

            <block wx:for="{{imgUrls}}" wx:key="index">

                <swiper-item>

                    <image src="{{item}}" class="slide-image"  />

                </swiper-item>

            </block>

        </swiper>

登录后复制
登录后复制

然而横向滑动需要注意些别的细节  
首先要给swiper组件加上scroll-x-="true"  
然后给轮播的子元素父容器设置display: inline-block; white-space: nowrap;

头条信息框转换采用上下轮换, 使用scroll-view嵌套swiper完成

1

2

3

4

5

6

7

    <scroll-view scroll-y-="true"  >

                <swiper autoplay="{{autoplay}}" interval="{{interval1}}" duration="{{duration}}" vertical="true">

                    <block wx:for="{{something}}" wx:key="index">

                         //内容 

                    </block>

                </swiper>

    </scroll-view>

登录后复制
登录后复制

2.分类商品管理

首先在index界面通过onLoad生命周期函数 ,
通过easy-moc获取后台数据,将必要的信息送给全局的globalData

1

2

3

4

5

6

wx.request({

      url: 'http://www.easy-mock.com/mock/5a1ffb42583969285ab22bb7/orderOnline/orderOnline',

      complete: res => {

        this.globalData.classifyList = res.data;

      },

    })

登录后复制
登录后复制

对于数据处理,需要理清哪些是全局信息, 哪些是局部信息
比如所有商品的信息,购物车里的商品,就得放到全局中 ,而有些比如当前界面的状态,一般放到当前界面的Data里面保存

而有些个人信息,比如出生年月,账号信息   则可以通过wx.setStorage 和wx.getStorage放入本地存储

3.购物车操作

购物车中的操作无非是些加加减减,需要自己不断调试,找出哪里不合常理
通过view,button里的bindtap等操作,实现对商品信息的修改,购物车状态的处理

举个例子  减少购物车中的商品的数量操作

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

reduceItems: function (e) {

    let carts = app.globalData.carts;    //获取购物车的信息

    let classifyList = app.globalData.classifyList;  //获取商品的信息

    for (let key of carts) {                        //遍历购物车数组

      if (key.id === e.target.dataset.id) {         //通过WXML中 view里面的bind-id传过来的参数进行查找

        key.cartSelected = true;

        if (key.num === 1) {                  //如果数量为1还要减

          key.num--;

          key.cartSelected = false;           //购物车不选中

          key.selected = false;               //商品中不选中

          app.globalData.carts = carts.filter((item) => {    //进行购物车中商品剔除

            return item.id != e.target.dataset.id;

          })

        else {

          key.num--;

        }

      }

    }

    let num = 0;                                 //实时更新购物车小计界面显示

    let totalPrice = 0;

    for (let key of carts) {

      if (key.cartSelected) {

        num += key.num;

        totalPrice += key.num * key.price;

      }

    }

    this.setData({                          //通过setData进行当前页面Data数据管理

      cart: app.globalData.carts,

      cartTotal: num,

      cartTotalPrice: totalPrice,

    })

  },

登录后复制
登录后复制

4.weui框架引入

在全局CSS样式中 添加的CSS适配于所有的页面,由此可以引入weui ,做一些界面真的很方便

1

@import './styles/weui.wxss';

登录后复制
登录后复制

总结

  1. 微信小程序的组件,API很强大,需要不断的探索,不断的学习,多看文档

  2. 善于利用有效资源, 比如iconfont  esay-moc weui等

  3. 切页面要细心,善于利用弹性布局等布局方法,小程序的rpx确实很好用

  4. 不要一股脑的写代码, 当函数具有复用性,应该抽象出来,封装好,这样代码才易于维护,易读。

以上内容就是仿盒马鲜生微信小程序,希望能帮助到大家。

相关推荐:

微信小程序开发入门实例

微信小程序视频,音乐,图片组件详解

微信小程序如何实现获取微信运动步数的案例(图)

以上是微信小程序-仿盒马鲜生 的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何在iPhone中使Google地图成为默认地图 如何在iPhone中使Google地图成为默认地图 Apr 17, 2024 pm 07:34 PM

如何在iPhone中使Google地图成为默认地图

如何通过C++编写一个简单的倒计时程序? 如何通过C++编写一个简单的倒计时程序? Nov 03, 2023 pm 01:39 PM

如何通过C++编写一个简单的倒计时程序?

iPhone中缺少时钟应用程序:如何修复 iPhone中缺少时钟应用程序:如何修复 May 03, 2024 pm 09:19 PM

iPhone中缺少时钟应用程序:如何修复

如何使用任务计划程序打开网站 如何使用任务计划程序打开网站 Oct 02, 2023 pm 11:13 PM

如何使用任务计划程序打开网站

iOS 17:如何在'信息”中组织iMessage应用程序 iOS 17:如何在'信息”中组织iMessage应用程序 Sep 18, 2023 pm 05:25 PM

iOS 17:如何在'信息”中组织iMessage应用程序

无法允许访问 iPhone 中的摄像头和麦克风 无法允许访问 iPhone 中的摄像头和麦克风 Apr 23, 2024 am 11:13 AM

无法允许访问 iPhone 中的摄像头和麦克风

C语言中的身份矩阵程序 C语言中的身份矩阵程序 Aug 30, 2023 am 10:45 AM

C语言中的身份矩阵程序

在Windows 11上下载和安装三星NVME驱动程序的方法 在Windows 11上下载和安装三星NVME驱动程序的方法 Aug 23, 2023 pm 06:01 PM

在Windows 11上下载和安装三星NVME驱动程序的方法

See all articles