前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >微信小程序电商实战—首页篇(上)

微信小程序电商实战—首页篇(上)

作者头像
游离于山间之上的Java爱好者
发布2022-09-21 08:59:27
9780
发布2022-09-21 08:59:27
举报
文章被收录于专栏:你我杂志刊你我杂志刊

上一篇 微信小程序电商实战—环境搭建篇

1、定义模块与设置头部

首先先在app.json文件中定义首页分类购物车以及我的四个模块。

背景颜色为白色,名称是秋码淘好货

代码语言:javascript
复制
 "pages":[
    "pages/index/index",
    "pages/category/category",
    "pages/cart/cart",
    "pages/personal/personal"
  ],
  "window":{
    "backgroundTextStyle":"light",
    "navigationBarBackgroundColor": "#fff",
    "navigationBarTitleText": "秋码淘好货",
    "navigationBarTextStyle":"black"
  },

2、滑块导航栏

编辑index.wxmlindex.wxss这两个文件

index.wxml

代码语言:javascript
复制
<view class="page">
  <!-- 搜索框 -->
  <view class="search">
    <view class="searchBar">
      <icon class="weui-icon-search" type="search" size="14"></icon>
      <input  class="input" placeholder="大家都在搜" bindtap="entrySearch" disabled />
    </view>
  </view>
  <!-- 导航栏 -->
  <view class="navBar">
      <scroll-view class="navBar-box" scroll-x="true" style="white-space: nowrap; display:flex ">
          <view class="cate-list {{curIndex==index?'on':''}}" wx:for="{{category}}" 
                wx:key="{{item.id}}" data-id="{{item.id}}" data-index="{{index}}" 
                bindtap="navbarTap">{{item.name}}</view>
      </scroll-view>
  </view>
</view>

index.wxss

代码语言:javascript
复制
.page{
  height:100%;
  display:flex;
  flex-direction:column;
  box-sizing:border-box;
  position:relative;
  top:0;
  left:0;
  bottom:0;
  right:0;
  background-color:#f5f8fa;
}
.search{
  background: #fff;
}
.searchBar{
  margin: 20rpx 30rpx;
  border-radius: 30px;
  border:1px solid #f5f5f5;
  background: #f5f5f5;
}
.weui-icon-search{
  margin-left: 15rpx;
  float: left;
}

.navBar{
  height: 60rpx;
  background: #fff;
  border-top: 1px solid #fafafa;
}
.navBar-box{
  width: 100%;
  height: 60rpx;
}
.cate-list{
  display: inline;
  margin: 15rpx 22rpx;
  text-align: center;
  font-size: 14px;
  color: #9d9d9d;
}
.navBar-box .cate-list.on {
  color: #000000;
  font-weight: bold;
}

index.wxml我们使用bindtap进行点击事件监听,设置事件名称为navbarTap并且在index.js里设置这个事件对应的逻辑处理。我们在组件上使用wx:for控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item,想要了解wx:for可以参考该资料:https://www.w3cschool.cn/weixinapp/weixinapp-list.html

index.js

代码语言:javascript
复制
//导航栏 
// pages/index/index.js
var app = getApp()
Page({
  data:{
    category: [       // 导航栏内容数据
      {name:'热门',id:"remen" },
      {name:'美食',id:'meishi'},
      {name:'居家',id:"jujia"},
      {name:'美妆',id:"meizhuang"},
      {name:'女装', id:"nvzhuang"},
      {name:'母婴',id:"muying"},
      {name:"男装",id:"nanzhuang"},
      {name:"鞋品",id:"xiepin"},
      {name:"箱包",id:"xiangbao"},
      {name:"配饰",id:"peishi"},
      {name:"儿童",id:"ertong"},
      {name:"数码",id:"shuma"},
      {name:"家电",id:"jiadian"},
      {name:"内衣",id:"neiyi"},
      {name:"车品",id:"chepin"},
      {name:"文体",id:"wenti"},
      {name:"宠物",id:"chongwu"},
      {name:"其他",id:"qita"}

    ],
    curIndex: 0,
    detail: [],
    toView: 'remen',
    scroll: true
  },
  navbarTap(e) {
    this.setData({
      curIndex: e.currentTarget.dataset.index?e.currentTarget.dataset.index:0,
      toView: e.currentTarget.dataset.index,
    })
  },

})

保存查看一下:

3、首页轮播图

在lindex.wxml添加以下内容

代码语言:javascript
复制
<swiper class="banner" indicator-dots autoplay indicator-active-color="#fbbd08" circular>
    <block wx:for="{{bannerList}}" wx:key="id">
      <swiper-item>
        <image lazy-load src="{{item.img}}"  class="banner_image" />
      </swiper-item>
    </block>
  </swiper>

index.wxss添加如下样式

代码语言:javascript
复制
.banner {
  width: 100%;
  display: flex;
  box-sizing: border-box;
  height: 184rpx;
}

.banner_image {
  width: 100%;
  padding: 16rpx 16rpx 12rpx 16rpx;
  display: flex;
  box-sizing: border-box;
  height: 160rpx;
}

index.js添加如下内容,在data对象添加一个数组对象。

代码语言:javascript
复制
bannerList:[
      {id:"one",img:"/images/banner/banner-one.png"},
      {id:"teo",img:"/images/banner/banner-two.png"},
      {id:"three",img:"/images/banner/banner-three.jpg"},
      {id:"four",img:"/images/banner/banner-four.jpg"}
    ],

最终实现的效果图如下:

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-03-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 你我杂志刊 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 上一篇 微信小程序电商实战—环境搭建篇
  • 1、定义模块与设置头部
  • 2、滑块导航栏
  • 3、首页轮播图
相关产品与服务
云开发 CloudBase
云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档