首页 > 编程语言 >02 uniapp/微信小程序 项目day02

02 uniapp/微信小程序 项目day02

时间:2022-09-21 18:13:34浏览次数:72  
标签:02 uniapp day02 搜索 跳转 组件 uni scroll 页面

一.分类

image-20220811180412249

1.1 页面布局

首先创建cate的分支

image-20220811181909502

定义基本结构,因为是两个需要滚动的区域,所以这里要用到组件 scroll

这个组件如果是y scroll那就要固定高度,x scroll那就要固定宽度

image-20220811182137238

这里有个问题就是,我们应该把高度限定在整个屏幕高度

这里用到uniapp一个api uni.getSystemInfoSync()他可以获得很多信息,比如该手机型号、以及平台、还有整个屏幕宽高以及内容区域宽高等

image-20220811183118618

image-20220811183256663

image-20220811183405538

1.2 一级分类

先获取数据

image-20220811184237539

然后开始渲染

注意block类似于template不占用空间组件

image-20220811184518481

然后动态active的变化

注意如果是多个class使用数组包起来

image-20220811184741906

然后点击事件

image-20220811184803197

image-20220811184825786

1.3 二三级分类

二三级分类是跟着一级分类一起来的数据,所以可以在一开始就接收第一个active的数据,再通过改变active的点击事件来切换列表

image-20220811190207108

image-20220811190238909

然后就可以渲染到页面

image-20220811190457622

二级分类就出来了

image-20220811190508708

三级分类直接渲染即可

image-20220811190732354

1.4 重置滚动条,跳转分包

现在的页面是有一个bug的

image-20220811192525159

当我们浏览一半到这里再次点击一级分类,会发现还是在这个位置,有点类似于路由的滚动行为

这里的解决思路是 scroll组件有一个属性scroll-top 可以定位到竖向滚动条的位置

image-20220811193016573

image-20220811193021587

image-20220811193033641

但是这样并不会生效,因为我们的scrollTop始终没变过,所以你给他赋值0,他发现他本来就是0就不会有赋值的操作,页面也就响应不到

image-20220811193233820

然后点击三级分类每一项跳转到分包商品详情页去

image-20220811195118194

注意tabBar是用switchTap来跳,分包非tabBar页面使用navigateTo来跳

image-20220811195526052

1.5 分支合并提交

主要就是记住分支暂存提交推送后,到主分支要先暂存提交,再合并,再来推送

二.搜索

先创建search分支

image-20220816175223527

2.1 自定义搜索组件

image-20220816180335990

uni创建自定义组件

uni-modules新建插件

image-20220816175801886

image-20220816180012191

而且不用注册,直接在页面使用即可

image-20220816180231873

该效果本质上是在这里展示用的,当一点击回调往真正的搜索页面

image-20220816180415149

这里如果要把我们的背景颜色和边框圆角弄成动态的,其实就是vue的props

回忆一下对象写法

image-20220816182514455

用在组件上,注意属性名和值都要加引号

注意一下uni提供了一些组件,uniui在官方文档上

image-20220816182746852

接下来回顾一下自定义事件,也就是我们怎么让页面点击这个组件我们跳转到搜索页面

绑定自定义事件

image-20220816184552916

image-20220816183659404

组件通过emit,规定触发的时机以及发送数据

image-20220816183742497

image-20220816183813635

2.1.1 导航跳转与吸顶效果

首先导航跳转

先创建一个分包

image-20220816190954750

然后跳转非tabBar用navigateTO

image-20220816191137615

然后再home页面也需要一个

image-20220816191643533

image-20220816191710495

但是在这个页面就出现了问题,会跟着页面飘起走

image-20220816191831348

之所以cate页面没出现是因为它是用的scroll组件,他有滚动条,超出了就滚动条往下走了,所以search组件就可以一直在那里,但是还需要完善一下

用我们之前cate计算出来的高度减去search组件的高度

image-20220816192042996

然后解决首页这个问题,将它设置为sticky定位即可

image-20220816192559793

2.2 搜索建议

搜索页面的基本结构,这里有用到一个uni的组件有专门的搜索栏search-bar

image-20220816194607983

然后将取消按钮删除,去掉一些不必要的事件

image-20220816195101183

image-20220816195127494

要修改背景颜色要去这个组件内部去修改

image-20220816195304241

然后要让他一进来就获取焦点也是在内部去改,将两个都改为true

image-20220816195428183

该组件的input事件会受到参数e也就是输入的值

image-20220816195630969

image-20220816195642869

image-20220816195709342

image-20220816195714884

很明显这里要做一个防抖处理

image-20220816195911107

2.2.1 根据关键词搜索列表

这里的思路是这样的,在防抖里面调用一个获取搜索列表的函数,在这个函数里面应该先判断一下kw也就是输入的关键词是否是空,如果为空就让列表为空并退出循环否则就正常走,发起请求并给到数组

image-20220816200638311

image-20220816201113454

然后渲染到页面上

image-20220816201259859

同时跳转到商品详情页面

image-20220816201425149

2.3 搜索历史

先定义好ui结构

image-20220817182332714

来点假数据

image-20220817182634274

然后搜索建议列表和搜索历史应该条件渲染

image-20220817182825003

image-20220817182923317

2.3.1 搜索历史列表处理

同样还是input事件

image-20220817185629089

但是有两个问题

image-20220817185723448

一个是最新搜索的应该放在前面:

这里不改变push的用法的前提下,需要用计算节点来做,因为reverse会改变原数组,容易出差错,而且要浅拷贝一下也是怕把原数组改变到了

image-20220817190053184

还有一个问题就是我们搜重复的会显示两个在上面:

image-20220817191942805

这样做虽然可以去重操作,但是有一个问题 就是我们如果已经搜索了一个a,在最后面,在搜索一次a,虽然不会上去重复的,但是这个时候a应该在最前面去这样做的话这个a还是在最后面

其原因是因为原本结构是这样

image-20220817192130288

页面呈现是这样

image-20220817192140793

这个时候你输入a,先push进去,然后set发现重复,就直接删除了新进来的这个a,相当于没有变化,所以也不会引起计算属性reverse的变化,也就导致了你就算搜了一次a他也没有到最前面来

正确的做法应该这样

去掉我们原来的push,当我们input之后先创建一个set结构,用她的delete方法删除原来的,在add添加新的,这样结构也就变了,就算有重复的也会被删去重复的,而且最重要的是,新搜索的会在前面

image-20220817192628149

持久化存储搜索建议列表

大体思路是在我们存储进historyList的时候变成json字符串也保存进storage,用到uni的一个api uni.setStorageSync

image-20220817193936228

然后在onload生命钩子中去获取,注意要考虑没有的情况,就为一个空的字符串数组

image-20220817194245827

2.3.2 清空搜索历史记录

绑定事件

image-20220817194634391

需要将列表清空,同时记得移除storage里面的数据

image-20220817194702688

2.3.3 点击搜索历史跳转

image-20220817195013872

标签:02,uniapp,day02,搜索,跳转,组件,uni,scroll,页面
From: https://www.cnblogs.com/heymar/p/16716598.html

相关文章

  • uniapp H5与原生安卓的数据互通和方法调用
    1、准备我这里是uniapp与原生安卓之间的相互调用,也就是原生安卓内嵌H5页面,下面先来准备一下安卓端的代码。(1)、初始化的MainActivity类定义一个WebViewprivateWebView......
  • 报告分享|2021数据资产运营白皮书
    报告链接:http://tecdat.cn/?p=28600数字经济时代的来临,推动市场向着更灵活高效的形态演进,也促进了一批新业态和新模式的形成。而数据作为这一时代的核心要素,凭借其强大的......
  • protocol-buffer3语言指南-02
    AnyAny消息类型可以让你使用消息作为嵌入类型而不必持有他们的.proto定义.Any把任意序列化后的消息作为bytes包含,带有一个URL,工作起来类似一个全局唯一的标识符.为......
  • 【学习随笔】2022.9.21
     ①左扰动与右扰动的添加规则:          #参考链接①为什么要使用齐次坐标②三维空间刚体的旋转③李群与李代数浅讲......
  • uniapp未添加本地push模块
    1.引入push模块所需的jar/aar文件本地push模块需要这个文件:aps-release.aar,在SDK/libs目录下找到这个文件后复制到android\simpleDemo\libs目录下获取途径:下载androidsd......
  • 「JOISC 2020 Day4」治疗计划
    传送门思路淼淼题考虑一个朴素的DP:我们设\(f_i\)表示将\([1,R_i]\)的居民治好需要的最小代价对于转移\(f_i\longrightarrowf_j\),当且仅当\(R_i-L_j+1\ge|T_j......
  • 【2022-09-18】周日的忧伤
    20:00如果丧失对历史的记忆,我们的心灵就会在黑暗中迷失。                                  ......
  • 【2022-09-19】连岳摘抄
    23:59我们赚钱,靠的是记住浅显的,而不是掌握深奥的。我们从来不去试图成为非常聪明的人,而是持续地试图别变成蠢货,久而久之,我们这种人便能获得非常大的优势。    ......
  • 2022年vue3 10大开源后台管理系统模板
    当你写项目的时候,如何快速的完成一个项目的搭建,这个时候就需要借助到一些模板了,前端开发的一个好处就是,各类UI模板都是相当的齐全的,直接拿来用就可以了,脱离了一行又一行垒......
  • HO引擎近况20220921
    这俩月一直在忙公司的项目,好多事都要我来处理我打算在公司再买一台显示器组三显,但是公司的显卡太破了接口不够,我只好又买了一张显卡自从之前XGP被回收之后我也没有再......