【小程序实战系列】电商平台源码及功能实现,fluttertextfield赋值

}




[]( )4.2、home 首页

-------------------------------------------------------------------------



// home.js

import { fetchHome } from ‘…/…/services/home/home’;

import { fetchGoodsList } from ‘…/…/services/good/fetchGoods’;

import Toast from ‘tdesign-miniprogram/toast/index’;

Page({

data: {

imgSrcs: [],

tabList: [],

goodsList: [],

goodsListLoadStatus: 0,

pageLoading: false,

current: 1,

autoplay: true,

duration: 500,

interval: 5000,

navigation: { type: 'dots' },

},

goodListPagination: {

index: 0,

num: 20,

},

privateData: {

tabIndex: 0,

},

onShow() {

this.getTabBar().init();

},

onLoad() {

this.init();

},

onReachBottom() {

if (this.data.goodsListLoadStatus === 0) {

  this.loadGoodsList();

}

},

onPullDownRefresh() {

this.init();

},

init() {

this.loadHomePage();

},

loadHomePage() {

wx.stopPullDownRefresh();



this.setData({

  pageLoading: true,

});

fetchHome().then(({ swiper, tabList }) => {

  this.setData({

    tabList,

    imgSrcs: swiper,

    pageLoading: false,

  });

  this.loadGoodsList(true);

});

},

tabChangeHandle(e) {

this.privateData.tabIndex = e.detail;

this.loadGoodsList(true);

},

onReTry() {

this.loadGoodsList();

},

async loadGoodsList(fresh = false) {

if (fresh) {

  wx.pageScrollTo({

    scrollTop: 0,

  });

}



this.setData({ goodsListLoadStatus: 1 });



const pageSize = this.goodListPagination.num;

let pageIndex =

  this.privateData.tabIndex * pageSize + this.goodListPagination.index + 1;

if (fresh) {

  pageIndex = 0;

}



try {

  const nextList = await fetchGoodsList(pageIndex, pageSize);

  this.setData({

    goodsList: fresh ? nextList : this.data.goodsList.concat(nextList),

    goodsListLoadStatus: 0,

  });



  this.goodListPagination.index = pageIndex;

  this.goodListPagination.num = pageSize;

} catch (err) {

  this.setData({ goodsListLoadStatus: 3 });

}

},

goodListClickHandle(e) {

const { index } = e.detail;

const { spuId } = this.data.goodsList[index];

wx.navigateTo({

  url: `/pages/goods/details/index?spuId=${spuId}`,

});

},

goodListAddCartHandle() {

Toast({

  context: this,

  selector: '#t-toast',

  message: '点击加入购物车',

});

},

navToSearchPage() {

wx.navigateTo({ url: '/pages/goods/search/index' });

},

navToActivityDetail({ detail }) {

const { index: promotionID = 0 } = detail || {};

wx.navigateTo({

  url: `/pages/promotion-detail/index?promotion_id=${promotionID}`,

});

},

});


// home.json

{

“navigationBarTitleText”: “首页”,

“onReachBottomDistance”: 10,

“backgroundTextStyle”: “light”,

“enablePullDownRefresh”: true,

“usingComponents”: {

"t-search": "tdesign-miniprogram/search/search",

"t-loading": "tdesign-miniprogram/loading/loading",

"t-swiper": "tdesign-miniprogram/swiper/swiper",

"t-swiper-item": "tdesign-miniprogram/swiper/swiper-item",

"t-swiper-nav": "tdesign-miniprogram/swiper/swiper-nav",

"t-image": "/components/webp-image/index",

"t-icon": "tdesign-miniprogram/icon/icon",

"t-toast": "tdesign-miniprogram/toast/toast",

"t-tabs": "tdesign-miniprogram/tabs/tabs",

"t-tab-panel": "tdesign-miniprogram/tabs/tab-panel",

"goods-list": "/components/goods-list/index",

"load-more": "/components/load-more/index"

}

}


<t-loading

  theme="circular"

  size="40rpx"

  loading

  t-class-indicator="t-class-indicator"

>

	<span slot="text" class="loading-text">加载中...</span>

</t-loading>
<view class="search" bind:tap="navToSearchPage">

	<t-search

	  t-class-input="t-search__input"

	  t-class-input-container="t-search__input-container"

	  placeholder="iphone 13 火热发售中"

	  leftIcon=""

	  disabled

	>

		<t-icon

		  slot="left-icon"

		  prefix="wr"

		  name="search"

		  size="40rpx"

		  color="#bbb"

		/>

	</t-search>

</view>

<view class="swiper-wrap">

	<t-swiper

	  wx:if="{{imgSrcs.length > 0}}"

	  current="{{current}}"

	  autoplay="{{autoplay}}"

	  duration="{{duration}}"

	  interval="{{interval}}"

	  navigation="{{navigation}}"

	>

		<t-swiper-item wx:for="{{imgSrcs}}" wx:key="index">

			<t-image src="{{item.img}}" t-class="t-image__swiper" bind:tap="navToActivityDetail" />

		</t-swiper-item>

	</t-swiper>

</view>
<t-tabs

  t-class="t-tabs"

  t-class-active="t-class-item"

  t-class-track="t-class-track"

  defaultValue="{{0}}"

  bind:change="tabChangeHandle"

>

	<t-tab-panel

	  wx:for="{{tabList}}"

	  wx:for-index="index"

	  wx:key="index"

	  label="{{item.text}}"

	  value="{{item.key}}"

	/>

</t-tabs>

<goods-list

  wr-class="goods-list-container"

  goodsList="{{goodsList}}"

  bind:click="goodListClickHandle"

  bind:addcart="goodListAddCartHandle"

/>

<load-more list-is-empty="{{!goodsList.length}}" status="{{goodsListLoadStatus}}" bind:retry="onReTry" />

<t-toast id="t-toast" />

/* home.wxss */

page {

box-sizing: border-box;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
img

作者2013年从java开发,转做Android开发,在小厂待过,也去过华为,OPPO等大厂待过,18年四月份进了阿里一直到现在。

参与过不少面试,也当面试官 面试过很多人。深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长,而且极易碰到天花板技术停滞不前!

我整理了一份阿里P7级别的最系统的Android开发主流技术,特别适合有3-5年以上经验的小伙伴深入学习提升。

主要包括阿里,以及字节跳动,腾讯,华为,小米,等一线互联网公司主流架构技术。如果你想深入系统学习Android开发,成为一名合格的高级工程师,可以收藏一下这些Android进阶技术选型

我搜集整理过这几年阿里,以及腾讯,字节跳动,华为,小米等公司的面试题,把面试的要求和技术点梳理成一份大而全的“ Android架构师”面试 Xmind(实际上比预期多花了不少精力),包含知识脉络 + 分支细节。

Java语言与原理;
大厂,小厂。Android面试先看你熟不熟悉Java语言

高级UI与自定义view;
自定义view,Android开发的基本功。

性能调优;
数据结构算法,设计模式。都是这里面的关键基础和重点需要熟练的。

NDK开发;
未来的方向,高薪必会。

前沿技术;
组件化,热升级,热修复,框架设计

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

我在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多,CodeChina上可见;

当然,想要深入学习并掌握这些能力,并不简单。关于如何学习,做程序员这一行什么工作强度大家都懂,但是不管工作多忙,每周也要雷打不动的抽出 2 小时用来学习。

不出半年,你就能看出变化!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img
2689084457)]

NDK开发;
未来的方向,高薪必会。

[外链图片转存中…(img-cR4LXpWF-1712689084457)]

前沿技术;
组件化,热升级,热修复,框架设计

[外链图片转存中…(img-XY9UK04f-1712689084458)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

我在搭建这些技术框架的时候,还整理了系统的高级进阶教程,会比自己碎片化学习效果强太多,CodeChina上可见;

当然,想要深入学习并掌握这些能力,并不简单。关于如何学习,做程序员这一行什么工作强度大家都懂,但是不管工作多忙,每周也要雷打不动的抽出 2 小时用来学习。

不出半年,你就能看出变化!

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-6meEZBOc-1712689084458)]

  • 19
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值