以下是我之前学习黑马程序员课程的微信小程序所写的代码 除了支付功能都能实现。如果有错误的地方希望各位大佬能指正一下。

1.搜索框(searchinput)

#wxss
.search_input {
  height: 90rpx;
  padding: 10rpx;
  background-color: var(--themeColor);
}
.search_input navigator {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  border-radius: 15rpx;
  color: rgb(71, 69, 69);
}

2.小程序整体布局

#app.json
{
  "pages":[
    "pages/index/index",
    "pages/category/index",
    "pages/goods_list/index",
    "pages/goos_detail/index",
    "pages/cart/index",
    "pages/collect/index",
    "pages/order/index",
    "pages/search/index",
    "pages/user/index",
    "pages/feedback/index",
    "pages/login/index",
    "pages/auth/index",
    "pages/pay/index"
  ],
  "window":{
    "backgroundTextStyle":"light",
    "navigationBarBackgroundColor": "#ffd68f",
    "navigationBarTitleText": "Market",
    "navigationBarTextStyle":"white"
  },
  "tabBar": {
    "color": "#999",
    "selectedColor": "#0054ff",
    "backgroundColor": "#fff1ff",
    "position": "bottom",
    "borderStyle":"black",
    "list": [
      {
      "pagePath": "pages/index/index",
      "text": "首页",
      "iconPath": "icons/home.png",
      "selectedIconPath": "icons/home_1.png"
    }, 
      {
      "pagePath": "pages/category/index",
      "text": "二手商城",
      "iconPath": "icons/Category.png",
      "selectedIconPath": "icons/Category_1.png" 
    },
      {
      "pagePath": "pages/cart/index",
      "text": "购物车",
      "iconPath": "icons/cart.png",
      "selectedIconPath": "icons/cart_1.png"
    },
      {
      "pagePath": "pages/user/index",
      "text": "我的",
      "iconPath": "icons/my.png",
      "selectedIconPath": "icons/my_1.png"
    }
  ]
  },

  "sitemapLocation": "sitemap.json"
}
 
#app.wxss
@import"./styles/iconfont.wxss";
/* 在微信小程序中 不支持通配符 */
page,view,text,swiper,swiper-item,image,navigator{
  padding: 0; /*内边距*/
  margin: 0; /*外边距*/
  box-sizing: border-box; 
}
/* 主题颜色 通过变量来实现
    1 less中 存在 变量 这个知识
    2 原生的css和wxss 也是支持变量 
*/
page{
  /* 定义主题颜色 */ 
  --themeColor:#ffd68f;
  /* 
  定义统一字体大小 假设设计稿 大小是 375px
  1px=2rpx
 */
    font-size: 35rpx;
 


}
#下面一行代码关系到后面的图片能否正常加载
image{
  width: 100%;
}

3.局内使用图标

#iconfont.wxss
@font-face {
  font-family: "iconfont"; /* Project id 3176877 */
  src: url('//at.alicdn.com/t/font_3176877_3aikrnlzpca.woff2?t=1646482273692') format('woff2'),
       url('//at.alicdn.com/t/font_3176877_3aikrnlzpca.woff?t=1646482273692') format('woff'),
       url('//at.alicdn.com/t/font_3176877_3aikrnlzpca.ttf?t=1646482273692') format('truetype');
}

.iconfont {
  font-family: "iconfont" !important;
  font-size: 16px;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-biaoqianlan:before {
  content: "\e609";
}

.icon-tuanduizhaomu:before {
  content: "\e60d";
}

.icon-ziyuanpingtai-ziyuangongxiang:before {
  content: "\e608";
}

.icon-xuanchuan:before {
  content: "\e610";
}

.icon-ershou:before {
  content: "\f619";
}

.icon-icon_shoucang_xian:before {
  content: "\e604";
}

.icon-icon_shoucang_mian:before {
  content: "\e616";
}

.icon-daishouhuo:before {
  content: "\e641";
}

.icon-tuikuan:before {
  content: "\e75a";
}

.icon-shouye:before {
  content: "\e643";
}

.icon-daifukuan:before {
  content: "\e640";
}

.icon-dingdan:before {
  content: "\e897";
}

.icon-gouwuche:before {
  content: "\e63f";
}

.icon-kefu:before {
  content: "\e625";
}

.icon-fenxiang:before {
  content: "\eb24";
}

4.封装接口

#asyncWx.js
/**
 * promise形式的getSetting
 */
export const getSetting=()=>{
  return new Promise((resolve,reject)=>{
      wx.getSetting({
          success: (result)=>{
              resolve(result);
          },
          fail: (err)=>{
              reject(err);
          }
      });
  })
}
/**
* promise形式的chooseAddress
*/
export const chooseAddress=()=>{
  return new Promise((resolve,reject)=>{
      wx.chooseAddress({
          success: (result)=>{
              resolve(result);
          },
          fail: (err)=>{
              reject(err);
          }
      });
  })
}
/**
* promise形式的openSetting
*/
export const openSetting=()=>{
  return new Promise((resolve,reject)=>{
      wx.openSetting({
          success: (result)=>{
              resolve(result);
          },
          fail: (err)=>{
              reject(err);
          }
      });
  })
}
/**
* promise形式的 showModal
*/
export const showModal=({content})=>{
  return new Promise((resolve,reject)=>{
    wx.showModal({
        title: '提示',
        content: content,
        success :(res)=> {
            resolve(res);   
        },
        fail:(err)=>{
            reject(err);
        }
      })
  })
}
/**
* promise形式的 showToast
*/
export const showToast=({title})=>{
    return new Promise((resolve,reject)=>{
        wx.showToast({
            title: title,
            icon:'none',
            success :(res)=> {
                resolve(res);   
            },
            fail:(err)=>{
                reject(err);
            }
        })
    })
}
/**
* promise形式的 login
*/

export const login=()=>{
  return new Promise((resolve,reject)=>{
      wx.login({
        timeout: 10000,
        success:(result)=>{
            resolve(result);
        },
        fail:(err)=>{
            reject(err);
        }
      });
  })
}

/**
* promise形式的 小程序的微信支付
* @param{object} pay 支付所必要的参数
*/
export const requestPayment=(pay)=>{
  return new Promise((resolve,reject)=>{
      wx.requestPayment({
          ...pay,
          success:(result) =>{
              resolve(result)             
          },
          fail:(err)=>{
              reject(err);
          }
      });
  })
}

       5.首页(由于我并没有备份之前写的代码,我之前修改了首页的代码所以导致首页代码有缺失,体谅一下 )

#index.js
// index.js
// 获取应用实例
// 0 引入 用来发送请求的方法 一定要把路径补全
import {request} from "../../request/index"; 
Page({
  data: {
    //轮播图数组
    swiperList:[],
    //导航 数组
    catesList:[],
    //楼层数组
    floorList:[]
  },
  onLoad: function (options){

    // 1 发送异步请求获取轮播图数据
//     wx.request({
//       url: 'https://api-hmugo-web.itheima.net/api/public/v1/home/swiperdata',
//       success:(result)=>{
//         this.setData({
//           swiperList:result.data.message
//         })
// //         console.log(result); 

//         }
//     });
this.getSwiperList();
this.getCateList();
this.getFloorList();
},
// 获取轮播图数据
getSwiperList(){
  request({url:"/home/swiperdata"})
.then(result=> {
  
  this.setData({
    swiperList:result.data.message
  })
})
},
// 获取 分类导航数组
getCateList(){
  request({url:"/home/catitems"})
.then(result=> {
  this.setData({
    catesList:result.data.message
  })
})
},
// 获取 楼层数组
getFloorList(){
  request({url:"/home/floordata"})
.then(result=> {
  
  this.setData({
    floorList:result.data.message
  }) 
})
},
  onReady:function(){

  },
  onShow:function(){

  },
  onHide:function(){

  },
  onUnload:function(){

  },
  onPullDownRefresh:function(){

  },
  onReachBottom:function(){

  },
  onShareAppMessage:function(){

  },
  onPageScroll:function(){

  },
  // item(index,pagepath,text)
  onTabItemTap:function(item){
    
  }
})
 #index.json
{
  "usingComponents": {
    
    "searchinput":"../../components/searchinput/search input"
  },
  "navigationBarTitleText": "优购天堂 "
}

#index.wxml
<view class="yg_index">
<!-- 搜索框 开始 -->
<searchinput></searchinput>
<!-- 搜索框 结束 -->
<!-- 轮播图 开始 -->
<view class="index_swiper">
<!-- 
  1 swiper标签存在默认宽高 100%*150px
  2 image标签也存在默认的宽度和高度 320px*240px
  3 设计图片和轮播图 
     1 先看一下原图宽高 750*340
     2 让图片的高度自适应 宽度 等于 100%
     3 用swiper标签的高度  变成和图片一样的高度
  4 图片标签 
  mode属性 渲染模式
       widthfix 让图片标签宽高和图片标签的内容的宽高都等比例发生变化
 -->
<swiper autoplay indicator-dots circular >
<swiper-item
wx:for="{{swiperList}}"
wx:key="goods_id">
<navigator url="/pages/goos_detail/index?goods_id={{item.goods_id}}">
<image mode="widthFix" src="https://pic1.zhimg.com/v2-52086599c209dbabe98ac8844c8a0084_1440w.jpg?source=172ae18b"></image>
</navigator>
</swiper-item>
</swiper>
</view>
<!-- 轮播图 结束 -->

<!-- 导航 开始 -->
<view class="index_cate">
<navigator url="/pages/category/index"open-type="switchTab">
<view class="iconfont icon-ziyuanpingtai-ziyuangongxiang"></view>
<view class="cate_name">资源共享</view>
</navigator>  
<navigator url="/pages/category/index" open-type="switchTab" >
<view class="iconfont icon-xuanchuan"></view>
<view class="cate_name">帮宣传</view>
</navigator>  
<navigator url="/pages/category/index" open-type="switchTab" >
<view class="iconfont icon-ershou"></view>
<view class="cate_name">二手交易</view>
</navigator>  
<navigator url="/pages/category/index" open-type="switchTab" >
<view class="iconfont icon-tuanduizhaomu"></view>
<view class="cate_name">团队招募</view>
</navigator>  
</view>
<!-- 导航 结束 -->

<!-- 楼层 开始 -->
<view class="index_floor">
<view class="floor_group"
wx:for="{{floorList}}"
wx:for-item="item1"
wx:for-index="index1"
wx:key="floor_title"
>
<!-- 标题 -->
<view class="floor_title">
<image mode="widthFix" src="{{item1.floor_title.image_src}}"></image>
</view>
<!-- 内容 -->
<view class="floor_list">
<navigator
wx:for="{{item1.product_list}}"
wx:for-item="item2"
wx:for-index="index2"
wx:key="name"
url="/pages/goods_list/index?{{item2.navigator_url.join('?')[1]}}"
>
<image mode="{{index2===0? 'widthFix':'scaleTofill'}}"src="{{item2.image_src}}"></image>
</navigator>
</view>
</view>
</view>
<!-- 楼层 结束 -->
</view>


#index.wxss
.index_swiper swiper {
  width: 750rpx;
  height: 340rpx;
}
.index_swiper image {
  width: 100%;
}
.index_cate {
  background-color: #fff;
  margin-top: 20rpx;
  padding: 20rpx;
  border-bottom: 1rpx solid #ccc;
  display: flex;
}
.index_cate navigator {
  padding: 15rpx 0;
  flex: 1;
  text-align: center;
}
.index_cate navigator .iconfont {
  color: var(--themeColor);
}
.index_floor .floor_group .floor_title  {
  padding:10rpx 0rpx;
}
.index_floor .floor_group .floor_title image {
  width: 110%;
}
.index_floor .floor_group .floor_list navigator {
  float: left; 
  width: 33.33%;
  /* 后四个超链接*/
}
.index_floor .floor_group .floor_list navigator:nth-last-child(-n+4) {
  /* 原图的宽高 */
  /* 232/386=33.33vw/height */
  /* 第一张图片的高度 height:33.3vw*386/232 */
  height: 27.72711207vw;
  border-left:10rpx solid #fff;
}

.index_floor .floor_group .floor_list navigator:nth-last-child(4){
  border-bottom:10rpx solid #fff;
}
.index_floor .floor_group .floor_list navigator:nth-last-child(3){
  border-bottom:10rpx solid #fff;
}

.index_floor .floor_group .floor_list navigator image {
  width: 100%;
  height:100%;
}