搜索
首页微信小程序小程序开发微信小程序商城开发之动态API实现特卖商品的流式布局代码

本篇文章给大家带来的内容是关于微信小程序商城开发之动态API实现特卖商品的流式布局代码 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

看效果


开发计划

1、新品特卖商品列表布局
2、调用动态API获取数据并加载
3、点击商品跳转商品详情

根据商品ID获取商品详情API数据模型

访问:https://100boot.cn/ 选择微商城案例,如下图所示:


下方还有详细的数据模型可以查看哦!

brand.wxml

<scroll-view scroll-y="true" style="height:{{scrollH}}px" bindscrolltolower="brandShow">
  <view class="goods" style="width:100%">
    <view class="mg_item">
      <view wx:for="{{col1}}" wx:key="id">
      <view class="item_info" catchtap="catchTapCategory" data-goodsid="{{item.id}}">
        <image src="{{item.imgUrl}}" style="width:100%;height:{{item.height}}px"></image>
      </view>
            <view class="product-name">
              {{item.name}}            </view>
            <view class="product-price-wrap">
              <p class="product-price-new">¥{{item.price}}</p>  
              <p class="product-price-old">¥{{item.privilegePrice}}</p> 
               <p class="discount">{{item.discount}}折</p>   
            </view>
      </view>
    </view>
    <view class="mg_item">
      <view wx:for="{{col2}}" wx:key="id" >
      <view class="item_info" catchtap="catchTapCategory" data-goodsid="{{item.id}}">
        <image src="{{item.imgUrl}}" style="width:100%;height:{{item.height}}px"></image>
      </view>
            <view class="product-name">
              {{item.name}}            </view>
            <view class="product-price-wrap">
              <p class="product-price-new">¥{{item.price}}</p>  
              <p class="product-price-old">¥{{item.privilegePrice}}</p> 
               <p class="discount">{{item.discount}}折</p>   
            </view>
      </view>
    </view>
  </view></scroll-view>

 <view style="display:none">
  <image wx:for="{{brandGoods}}" wx:key="id" id="{{item.id}}" src="{{item.imgUrl}}" bindload="onImageLoad1"></image></view> 

  <view class="weui-loadmore" hidden="{{hidden}}">
    <view class="weui-loading"></view>
    <view class="weui-loadmore__tips">努力加载中</view>
  </view>

brand.wxss

page{  
  height: 100%;  
  background-color: #F3F4F6;
} 
/* 单个图片容器的样式 */
.img_item {  
    width: 48.5%;  
    margin: 2px;  
    display: inline-block;  
    vertical-align: top;  
    background-color: #ffffff;  
    font-size: 24rpx;
}
.item_info{   
    border-top:5px solid #F3F4F6; 
}
.product-name{  
    color: #000;  /* height: 28px; */
    text-align:left;   margin: 0px 5px; 
    margin-bottom: 5px; 
}
.product-price-wrap .product-price-new{  
    color: #e80080;  
    margin-left:5px;  
    font-weight:900;
}
.product-price-wrap .product-price-old{  
    color: #888;  
    text-decoration: line-through;  
    padding-left: 2px;
}
.product-price-wrap .discount{  
    margin-left: 30px;  
    background-color: #000;  
    color: #fff;
}
/*  加载更多   */

.weui-loading {  
    margin: 0 5px;  
    width: 20px;  
    height: 20px;  
    display: inline-block;      
    vertical-align: middle;  
    -webkit-animation: weuiLoading 1s steps(12, end) infinite;  
    animation: weuiLoading 1s steps(12, end) infinite;  
    background: transparent url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMjAiIGhlaWdodD0iMTIwIiB2aWV3Qm94PSIwIDAgMTAwIDEwMCI+PHBhdGggZmlsbD0ibm9uZSIgZD0iTTAgMGgxMDB2MTAwSDB6Ii8+PHJlY3Qgd2lkdGg9IjciIGhlaWdodD0iMjAiIHg9IjQ2LjUiIHk9IjQwIiBmaWxsPSIjRTlFOUU5IiByeD0iNSIgcnk9IjUiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAgLTMwKSIvPjxyZWN0IHdpZHRoPSI3IiBoZWlnaHQ9IjIwIiB4PSI0Ni41IiB5PSI0MCIgZmlsbD0iIzk4OTY5NyIgcng9IjUiIHJ5PSI1IiB0cmFuc2Zvcm09InJvdGF0ZSgzMCAxMDUuOTggNjUpIi8+PHJlY3Qgd2lkdGg9IjciIGhlaWdodD0iMjAiIHg9IjQ2LjUiIHk9IjQwIiBmaWxsPSIjOUI5OTlBIiByeD0iNSIgcnk9IjUiIHRyYW5zZm9ybT0icm90YXRlKDYwIDc1Ljk4IDY1KSIvPjxyZWN0IHdpZHRoPSI3IiBoZWlnaHQ9IjIwIiB4PSI0Ni41IiB5PSI0MCIgZmlsbD0iI0EzQTFBMiIgcng9IjUiIHJ5PSI1IiB0cmFuc2Zvcm09InJvdGF0ZSg5MCA2NSA2NSkiLz48cmVjdCB3aWR0aD0iNyIgaGVpZ2h0PSIyMCIgeD0iNDYuNSIgeT0iNDAiIGZpbGw9IiNBQkE5QUEiIHJ4PSI1IiByeT0iNSIgdHJhbnNmb3JtPSJyb3RhdGUoMTIwIDU4LjY2IDY1KSIvPjxyZWN0IHdpZHRoPSI3IiBoZWlnaHQ9IjIwIiB4PSI0Ni41IiB5PSI0MCIgZmlsbD0iI0IyQjJCMiIgcng9IjUiIHJ5PSI1IiB0cmFuc2Zvcm09InJvdGF0ZSgxNTAgNTQuMDIgNjUpIi8+PHJlY3Qgd2lkdGg9IjciIGhlaWdodD0iMjAiIHg9IjQ2LjUiIHk9IjQwIiBmaWxsPSIjQkFCOEI5IiByeD0iNSIgcnk9IjUiIHRyYW5zZm9ybT0icm90YXRlKDE4MCA1MCA2NSkiLz48cmVjdCB3aWR0aD0iNyIgaGVpZ2h0PSIyMCIgeD0iNDYuNSIgeT0iNDAiIGZpbGw9IiNDMkMwQzEiIHJ4PSI1IiByeT0iNSIgdHJhbnNmb3JtPSJyb3RhdGUoLTE1MCA0NS45OCA2NSkiLz48cmVjdCB3aWR0aD0iNyIgaGVpZ2h0PSIyMCIgeD0iNDYuNSIgeT0iNDAiIGZpbGw9IiNDQkNCQ0IiIHJ4PSI1IiByeT0iNSIgdHJhbnNmb3JtPSJyb3RhdGUoLTEyMCA0MS4zNCA2NSkiLz48cmVjdCB3aWR0aD0iNyIgaGVpZ2h0PSIyMCIgeD0iNDYuNSIgeT0iNDAiIGZpbGw9IiNEMkQyRDIiIHJ4PSI1IiByeT0iNSIgdHJhbnNmb3JtPSJyb3RhdGUoLTkwIDM1IDY1KSIvPjxyZWN0IHdpZHRoPSI3IiBoZWlnaHQ9IjIwIiB4PSI0Ni41IiB5PSI0MCIgZmlsbD0iI0RBREFEQSIgcng9IjUiIHJ5PSI1IiB0cmFuc2Zvcm09InJvdGF0ZSgtNjAgMjQuMDIgNjUpIi8+PHJlY3Qgd2lkdGg9IjciIGhlaWdodD0iMjAiIHg9IjQ2LjUiIHk9IjQwIiBmaWxsPSIjRTJFMkUyIiByeD0iNSIgcnk9IjUiIHRyYW5zZm9ybT0icm90YXRlKC0zMCAtNS45OCA2NSkiLz48L3N2Zz4=) no-repeat;  
    background-size: 100%;
}
.weui-loadmore {  
    width: 65%;  
    margin: 1.5em auto;  
    line-height: 1.6em;  
    font-size: 12px;  
    text-align: center;
}
.weui-loadmore__tips {  
    display: inline-block;  
    vertical-align: middle;  
    color: #888;
}

brand.js

const ajax = require(&#39;../../utils/ajax.js&#39;);
const utils = require(&#39;../../utils/util.js&#39;);
var sectionData = [];
var ifLoadMore = null;
var activityId = null;
var page = 1;//默认第一页

Page({  
    data: {    
        scrollH: 0,    
        imgWidth: 0,    
        loadingCount: 0,    
        images: [],    
        col1: [],    
        col2: []
  },  
    onLoad: function (options) {
    activityId = options.activityId;
    page = 1;   
    console.log(&#39;activityId:&#39; + activityId);
    wx.getSystemInfo({      
    success: (res) => {        
    let ww = res.windowWidth;        
    let wh = res.windowHeight;        
    let imgWidth = ww * 0.48;        
    let scrollH = wh;        
    this.setData({          
    scrollH: scrollH,          
    imgWidth: imgWidth
        });        
        //加载首组图片
        // this.loadImages();
        this.brandShow();
      }
    })
  },  
onImageLoad1: function (e) {    
     let imageId = e.currentTarget.id;    
     let oImgW = e.detail.width;         //图片原始宽度
    let oImgH = e.detail.height;        //图片原始高度
    let imgWidth = this.data.imgWidth;  //图片设置的宽度
    let scale = imgWidth / oImgW;        //比例计算
    let imgHeight = oImgH * scale;      //自适应高度

    let images = this.data.brandGoods;    
     let imageObj = null;    
     for (let i = 0; i < images.length; i++) {      
     let img = images[i];      
     if (img.id+"" === imageId) {
        imageObj = img;        
         break;
      }
    }

    imageObj.height = imgHeight;    
    let loadingCount = this.data.loadingCount - 1;    
    let col1 = this.data.col1;    
    let col2 = this.data.col2;    //判断当前图片添加到左列还是右列
    if (col1.length <= col2.length) {
      col1.push(imageObj);
    } else {
      col2.push(imageObj);
    }    
    let data = {      
        loadingCount: loadingCount,      
        col1: col1,      
        col2: col2
    };    
    //当前这组图片已加载完毕,则清空图片临时加载区域的内容
    if (!loadingCount) {
      data.images = [];
    }    
    this.setData(data);
  },  
    brandShow: function (success) {    
        var that = this;    
        console.log(page)
        ajax.request({      
        method: &#39;GET&#39;,      
        url: &#39;goods/getActivityGoodsList?key=&#39; + utils.key + &#39;&activityId=&#39; + activityId+&#39;&page=&#39; + page + &#39;&size=10&#39;,      
        success: data => {        
        var newGoodsData = data.result.list;
        page += 1;        
        if (ifLoadMore) {          //加载更多
          if (newGoodsData.length > 0) {            
            console.log(newGoodsData)
            sectionData[&#39;brandGoods&#39;] = newGoodsData;
          } else {
            ifLoadMore = false;            
            this.setData({              
                hidden: true
            })
            
            wx.showToast({              
                title: &#39;暂无更多内容!&#39;,              
                icon: &#39;loading&#39;,              
                duration: 2000
            })
          }

        } else {          
            if (ifLoadMore == null) {
            ifLoadMore = true;
            sectionData[&#39;brandGoods&#39;] = newGoodsData;//刷新
          }
        }
        that.setData({          
            brandGoods: sectionData[&#39;brandGoods&#39;],          
            loadingCount: sectionData[&#39;brandGoods&#39;].length,
        });        
            console.log(that.data.brandGoods)
        wx.stopPullDownRefresh();//结束动画
      }
    })
  },  
catchTapCategory: function (e) {    
     var that = this;    
     var goodsId = e.currentTarget.dataset.goodsid;    
     console.log(&#39;goodsId:&#39; + goodsId);    //新增商品用户点击数量
    that.goodsClickShow(goodsId);    //跳转商品详情
    wx.navigateTo({ url: &#39;../detail/detail?goodsId=&#39; + goodsId    })
  },
  goodsClickShow(goodsId) {    
     console.log(&#39;增加商品用户点击数量&#39;);    var that = this;
    ajax.request({      
     method: &#39;GET&#39;,      
     url: &#39;goods/addGoodsClickRate?key=&#39; + utils.key + &#39;&goodsId=&#39; + goodsId,      
     success: data => {        
     console.log("用户点击统计返回结果:" + data.message)
      }
    })
  },
})

相关推荐:

微信小程序商城开发之动态API实现商品的详情页的代码(下)

微信小程序商城开发之商城首页轮播图、商品分类导航以及新品特卖的实现代码

以上是微信小程序商城开发之动态API实现特卖商品的流式布局代码的详细内容。更多信息请关注PHP中文网其他相关文章!

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

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具