前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【小程序项目开发-- 京东商城】uni-app之分类导航区域

【小程序项目开发-- 京东商城】uni-app之分类导航区域

作者头像
计算机魔术师
发布2022-08-23 09:41:12
1.3K0
发布2022-08-23 09:41:12
举报
文章被收录于专栏:计算机魔术师

👋👋欢迎来到👋👋 🎩魔术之家!!🎩 该文章收录专栏 ✨-- 2022微信小程序京东商城实战 --✨ 专栏内容 ✨-- 京东商城uni-app项目搭建 --✨ ✨-- 京东商城uni-app 配置tabBar & 窗口样式 --✨ ✨-- 京东商城uni-app开发之分包配置 --✨ ✨-- 京东商城uni-app开发之轮播图 --✨ ✨-- 京东商城uni-app之分类导航区域 --✨ ✨-- 京东商城uni-app 首页楼层商品 --✨ ✨-- 京东商城uni-app 商品分类页面(上) --✨ ✨-- 京东商城uni-app 商品分类页面(下) --✨ ✨-- 京东商城uni-app之自定义搜索组件(上) --✨ ✨-- 京东商城uni-app之自定义搜索组件(中) --✨

文章目录

实现目标:

一、封装uni.$showMsg()

  • 开发场景

在项目中,我们经常需要多次调取数据,而当数据请求失败之后,经常需要调用 uni.showToast({ /* 配置对象 */ }) 方法来提示用户。此时,可以在全局封装一个 uni.$showMsg() 方法,来简化 uni.showToast() 方法的调用。

具体的改造步骤如下: 在main.js 项目入口文件中,为uni挂载一个showMsg() 方法, 表示自定义挂载函数

在函数上是赋值参数用=, 在showToast函数内传的是一个字典,里面赋值是:

代码语言:javascript
复制
// 挂载 uni请求数据消息提示 方法 (默认)
uni.$showMsg = function(title = '数据加载错误...', duration = 1500,icon = 'fail' ) {
  uni.showToast({
    title,
    duration,
    icon
  })
}

将封装好的代码 用于home页面,

代码语言:javascript
复制
 onLoad() {
      // 调取方法,获取轮播图数据
      this.getSwiperList()
    },
    methods: {
      async getSwiperList() {
        // '/' 根目录即为在main.js的文件配置的 baseUrl 
        const res = await uni.$http.get('/api/public/v1/home/swiperdata')
        // 数据调取失败
        if (res.data.meta.status != 200) return uni.$showMsg()

        // 将调用的数据 赋值
        this.swiperList = res.data.message
        uni.$showMsg('数据请求成功!', 'success')
      }
    }

二、 响应数据参考

代码语言:javascript
复制
{
    "message": [
        {
            "image_src": "https://www.zhengzhicheng.cn/pyg/banner1.png",
            "open_type": "navigate",
            "goods_id": 129,
            "navigator_url": "/pages/goods_detail/main?goods_id=129"
        },
        {
            "image_src": "https://www.zhengzhicheng.cn/pyg/banner2.png",
            "open_type": "navigate",
            "goods_id": 395,
            "navigator_url": "/pages/goods_detail/main?goods_id=395"
        },
        {
            "image_src": "https://www.zhengzhicheng.cn/pyg/banner3.png",
            "open_type": "navigate",
            "goods_id": 38,
            "navigator_url": "/pages/goods_detail/main?goods_id=38"
        }
    ],
    "meta": { "msg": "获取成功", "status": 200 }
}

三、获取分类导航数据

  • 在data节点定义navList 数据
代码语言:javascript
复制
   data() {
      return {
        // 轮播图数组
        swiperList: [],
        //分类导航数组
        navList: []
      };
  • 在method 定义调取数据函数getNavList()
代码语言:javascript
复制
async getNavList(){
        // 调取数据
        const res =  await uni.$http.get('/api/public/v1/home/catitems')
        // 如果调取失败 返回错误信息并退出
        if(res.data.meta.status != 200 ) return uni.$showMsg()
        // 赋值
        this.navList =  res.data.message
        uni.$showMsg('数据加载成功','success')
      }
}
  • 在生命周期函数onload调用函数getNavList()
代码语言:javascript
复制
 onLoad() {
    // 调取方法,获取轮播图数据
    this.getSwiperList(),
    // 获取分类导航数据
    this.getNavList()
  },

调取成功

四、分类导航UI结构

在需要循环标签的属性节点需要在前面加上 :提示后面的是变量或变量表达式

3.1大坑勿踩!!!

  • 大坑一:使用 vue-for 动态循环轮播图数组,循环动态绑定需要标签属性节点前都要加上 ::v-bind:的缩写,即动态绑定数据,后面的是变量或者变量表达式,如果没有冒号的则为字符串,此时循环无法正常显示效果、)
  • 大坑二:在UI渲染 template模板一定需要一个 标签 view 将全部内容包裹起来,不然会报如下错误: Templates should only be responsible for mapping the state to the UI. Avoid placing tags with side-effects in your templates, such as <style>, as they will not be parsed. 这是因为在模板中必须要有一个 根节点,以这个根节点作为入口,递归遍历各个树叶(子标签)
代码语言:javascript
复制
<!-- 模板  -->
<template>
  <view>
    <!-- 渲染轮播图UI结构 -->
    <swiper :indicator-dots="true" :autoplay="true" :interval="3000" :duration="1000" :circular="true">
      <!-- 类似python for i,j in object 得到对应项目i以及索引j -->
      <swiper-item v-for="(item,i) in swiperList" :key="i">
        <navigator class="swiper-item" :url="'/subpackages/goods_detail/goods_detail?good_id=' + item.goods_id">
          <image :src="item.image_src"></image>
        </navigator>
      </swiper-item>
    </swiper>
  
  <view class="nav_list">
    <view class="nav_item" v-for="(item,index) in navList" :key="index">
      <image :src="item.image_src" class="nav_image"></image>
    </view>
  </view>
  
  </view>
</template>


<!-- 样式 -->
  <style lang="scss">
    .nav_list {
      display: flex;
    }
    .nav_item{
      display: flex;
      width: 25%;
      height: 200rpx;
      justify-content: center;
      align-items: center;
    }
      
    .nav_image {
      width: 150rpx;
      height:150rpx;
    }
  </style>

开发中可将页面复制到分栏,进行样式与结构开发

效果:

五、点击分类选项跳转到分类页面

前情提要:

监听DOM(document object model)事件在vue中使用v-on:, 而在小程序开发工具中监听事件则是 bind[’状态‘] ,如:bindtap,但是由于绑定事件v-on:经常需要被使用,所以使用@作为v-on:的缩写(前文提到的v-bind:也是一样:缩小,这是动态渲染数据,在小程序开发工具则是以mustache语法{{}}渲染数据的

由于需要对其选项判断是否为分类选项,所以不能简单的讲view改为navigator,需要监听点击事件,做更复杂的操作。

代码语言:javascript
复制
//方法
 methods: {
      // 分类导航-- 分类
      navClickHandelr(item){
        if (item.name === '分类') {
          uni.switchTab({
            url: "/pages/cate/cate"
          })
        }
      },

<!--UI结构--!>
 <view class="nav_list">
 <!--传参item--!>
    <view class="nav_item" v-for="(item,index) in navList" :key="index" v-on:click="navClickHandelr(item)">
      <image :src="item.image_src" class="nav_image"></image>
    </view>
  </view>

效果:

成功实现!🥳

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022/07/19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、封装uni.$showMsg()
  • 二、 响应数据参考
  • 三、获取分类导航数据
  • 四、分类导航UI结构
    • 3.1大坑勿踩!!!
    • 五、点击分类选项跳转到分类页面
    相关产品与服务
    云开发 CloudBase
    云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档