【小程序项目开发-- 京东商城】uni-app之首页商品楼层

简介: 【小程序项目开发-- 京东商城】uni-app之首页商品楼层

专栏内容

✨-- 京东商城uni-app项目搭建 --✨

✨-- 京东商城uni-app 配置tabBar & 窗口样式 --✨

✨-- 京东商城uni-app开发之分包配置 --✨

✨-- 京东商城uni-app开发之轮播图 --✨

✨-- 京东商城uni-app之分类导航区域 --✨

✨-- 京东商城uni-app 首页楼层商品 --✨

✨-- 京东商城uni-app 商品分类页面(上) --✨

✨-- 京东商城uni-app 商品分类页面(下) --✨

✨-- 京东商城uni-app之自定义搜索组件(上) --✨

✨-- 京东商城uni-app之自定义搜索组件(中) --✨

文章目录

一、效果图:

图片.png

二、数据获取:

  • 数据接口样式【分为标题(包括图片,文字),列表(图片文字)】
{
    "message": [
        {
            "floor_title": {
                "name": "时尚女装",
                "image_src": "https://www.zhengzhicheng.cn/pyg/pic_floor01_title.png"
            },
            "product_list": [
                {
                    "name": "优质服饰",
                    "image_src": "https://www.zhengzhicheng.cn/pyg/pic_floor01_1@2x.png",
                    "image_width": "232",
                    "open_type": "navigate",
                    "navigator_url": "/pages/goods_list?query=服饰"
                },
                {
                    "name": "春季热门",
                    "image_src": "https://www.zhengzhicheng.cn/pyg/pic_floor01_2@2x.png",
                    "image_width": "233",
                    "open_type": "navigate",
                    "navigator_url": "/pages/goods_list?query=热"
                },
                {
                    "name": "爆款清仓",
                    "image_src": "https://www.zhengzhicheng.cn/pyg/pic_floor01_3@2x.png",
                    "image_width": "233",
                    "open_type": "navigate",
                    "navigator_url": "/pages/goods_list?query=爆款"
                },
                {
                    "name": "倒春寒",
                    "image_src": "https://www.zhengzhicheng.cn/pyg/pic_floor01_4@2x.png",
                    "image_width": "233",
                    "open_type": "navigate",
                    "navigator_url": "/pages/goods_list?query=春季"
                },
                {
                    "name": "怦然心动",
                    "image_src": "https://www.zhengzhicheng.cn/pyg/pic_floor01_5@2x.png",
                    "image_width": "233",
                    "open_type": "navigate",
                    "navigator_url": "/pages/goods_list?query=心动"
                }
            ]
        },
    "meta": { "msg": "获取成功", "status": 200 }
}
  • 定义data数据
 data() {
      return {
        // 楼层数据数组
        floorList: []
      };
  • method定义调取数据方法
//获取楼层导航数据
      async getfloorList() {
        const {
          data: res
        } = await uni.$http.get('/api/public/v1/home/floordata')
        //如果调取失败 显示报错提示
        if (res.meta.status != 200) return uni.$showMsg()
        this.floorList = res.message
      },
  • onload调取函数图片.png

三、UI 界面渲染

  • 在动态循环数据列表渲染页面图片等,可以使用vue 语法 v-bind:,动态绑定,也支持mustache语法 ,但是只限于将文字等一些输出用mustache语法 如输出标题文字,组件内属性还是不支持mustache语法的

且对于所得到图片得样式动态 style 中 需要 后面加上 {} 表示动态渲染

<!-- 楼层区域 -->
    <!-- 楼层容器 -->
    <view class="">
      <!-- 楼层 item -->
      <view class="floor_list" v-for="(item,index) in floorList" v-bind:key="index">
        <!-- 楼层标题 -->
        <view class="floor_title">
          <image v-bind:src="item.floor_title.image_src" class="floor_title_image" mode="widthFix"></image>
          <!-- <text>{{item.floor_title.name}}</text> -->
        </view>
        <!-- 楼层列表 -->
        <view class="floor_product">
          <!-- 左侧大图片 -->
          <view class="left-img-box">
            <!-- 拼接 不全单位px -->
            <image :src="item.product_list[0].image_src" :style="{width: item.product_list[0].image_width + 'rpx'}">
            </image>
          </view>
          <!-- 右侧图片列表 -->
          <view class="right-img-box">
            <!-- 判断索引为0得情况 -->
            <view class="right-img-item" v-for="(product,i) in item.product_list" v-bind:key="i" v-if="i != 0">
              <image :src="product.image_src" :style="{width: product.image_width + 'rpx'}" mode="widthFix">
            </view>
            </image>
          </view>
        </view>
      </view>
    </view>
//注释:样式
  .floor_title {
    display: flex;
    flex-direction: column;
  }
  .floor_title image {
    height: 60rpx;
    width: 100%;
  }
  .floor_product {
    display: flex;
    padding: 10rpx;
  }
  .right-img-box {
    justify-content: space-around;
    display: flex;
    flex-wrap: wrap;
  }

在设置样式中 自动换行样式为
flex-wrap: wrap;
而不能使用
white-space: normal

这是因为display:flex 会与white-space: normal导致样式冲突,无法达到效果

效果图:

12.gif


四、跳转到商品页

图片.png

    图片.png

4.1、处理接口URL地址

  • 在实际中接口所给的URL地址与自己的命名页面不匹配,且需要对应页面参数,则需要对其进行操作

由于调取数据和渲染页面是同步操作,所以这里处理URl链接则使用forEach循环

他与for区别在于 (for&forEach文章讲解 & 箭头函数

  • for是通过下标来索引对应数据,forEach是 JavaScript定义的数组的函数方法 通过 JavaScript底层程序 循环遍历数组的数据元素,原理是指针指向,所以在面对几百万数据集,for可能会卡,forEach还是几毫秒。
  • for 可以通过break 中断, forEach不可以
  • forEach是数组的函数方法,无法进行对变量进行赋值修改等操作

两者最大的区别

  • 🎏forEach 是一种函数 可以通过设定参数 来 存储索引下标数据数值,这样在操作上更加的便利
  • 🎏for循环的执行 只能是通过循环生成索引下标数值 然后通过索引下标 操作 数组的数据元素

图片.png

  • 实现代码
 methods: {
   //获取楼层导航数据
   async getfloorList() {
     const {
       data: res
     } = await uni.$http.get('/api/public/v1/home/floordata')
     //如果调取失败 显示报错提示
     if (res.meta.status != 200) return uni.$showMsg()
     // 双重forEach循环修改URL
     res.message.forEach(floor => {  
       floor.product_list.forEach(prd => {  
         prd.navigator_url = '/subpackages/goods_list/goods_list?' + prd.navigator_url.split('?')[1]  //切割为列表 取后面的页面参数
       })
     })
     this.floorList = res.message
   },

成功修改

图片.png

五、配置页面组件navigator跳转页面

  • 将对应 商品页的view 改为 navigator 组件
 <!-- 楼层区域 -->
    <!-- 楼层容器 -->
    <view class="">
      <!-- 楼层 item -->
      <view class="floor_list" v-for="(item,index) in floorList" v-bind:key="index">
        <!-- 楼层标题 -->
        <view class="floor_title">
          <image v-bind:src="item.floor_title.image_src" class="floor_title_image" mode="widthFix"></image>
          <!-- <text>{{item.floor_title.name}}</text> -->
        </view>
        <!-- 楼层项目列表 -->
        <view class="floor_product">
          <!-- 左侧大图片 -->
          <navigator class="left-img-box" :url="item.product_list[0].navigator_url">
            <!-- 拼接 不全单位px -->
            <image :src="item.product_list[0].image_src" :style="{width: item.product_list[0].image_width + 'rpx'}">
            </navigator>
          <!-- 右侧图片列表 -->
          <view class="right-img-box">
            <!-- 判断索引为0得情况 -->
            <navigator class="right-img-item" v-for="(product,i) in item.product_list" v-bind:key="i" v-if="i != 0" :url="product.navigator_url">
              <image :src="product.image_src" :style="{width: product.image_width + 'rpx'}" mode="widthFix">
            </navigator>
            </image>
          </view>
        </view>
      </view>
    </view>

接受页面参数,并渲染为窗口标题

在goods_list.vue文件中

export default {
    data() {
      return {
        title:''   //定义参数
      };
    },
    onLoad(options){
      this.title = options  // 接收参数并赋值
      },
    onReady(){
      uni.setNavigationBarTitle({
        title: this.title.query  // 编程时 设置样式
      })
    }

效果:

13.gif

六、分支合并与提交(选读*)

  • 将本地home分支合并到master分支
  • 代码推送到远程仓库
  • 删除分支

操作

  1. git branch 注释: 查看当前分支
  2. git status 注释:查看当前文件状态
  3. git add . 注释:添加所有文件到暂存区
  4. git commit -m “完成了首页功能的开发” 注释:提交到本地仓库
  5. git push -u origin home 注释: -u是配置 upstream,提交本地仓库到远程仓库的分支home保存,确定了默认主机
  6. git checkout master 注释:切换分支到master
  7. git merge home 注释: 合并分支
  8. giit push 注释:由于前面-u 设置了upstearm 所以这次默认提交到master 分支(不需要其他参数)
  9. git branch -d home 注释:删除本地home分支

图片.png

✨谢谢你的阅读,您的点赞和收藏就是我创造的最大动力!


相关文章
|
29天前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
427 7
|
28天前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
488 1
家政服务小程序APP开发,做好上门家政最快的方法是什么?
在家政服务领域,打造成功的平台并非易事。本文分享了三个关键步骤:避免初期盲目投入、采用低成本获客方式、建立有效的阿姨筛选机制。遵循这些方法,可助你避开常见陷阱,成为行业头部平台。
|
14天前
|
小程序 数据挖掘 UED
开发1个上门家政小程序APP系统,都有哪些功能?
在快节奏的现代生活中,家政服务已成为许多家庭的必需品。针对传统家政服务存在的问题,如服务质量不稳定、价格不透明等,我们历时两年开发了一套全新的上门家政系统。该系统通过完善信用体系、提供奖励机制、优化复购体验、多渠道推广和多样化盈利模式,解决了私单、复购、推广和盈利四大痛点,全面提升了服务质量和用户体验,旨在成为家政行业的领导者。
|
29天前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
192 3
|
1月前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
173 1
|
11天前
|
小程序 测试技术
上门家政维修系统软件开发,一套类似啄木鸟维修的小程序APP只要3000你敢信?
在数字化商业时代,一款名为“啄木鸟维修”的小程序 APP 以 3000 元的价格亮相,引发了广泛关注。这款 APP 功能全面,支持自营或入驻模式,提供完善的售后服务和详细的运营策略,开发周期仅需 3-5 天。它是否物超所值,还需用户自行判断,但其在市场中的表现确实引人注目。
|
28天前
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
290 0
|
1月前
|
小程序 数据可视化 API
低代码可视化-uniapp商城首页小程序-代码生成器
低代码可视化-uniapp商城首页小程序-代码生成器
25 0
|
1月前
|
小程序
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
434 0

热门文章

最新文章