智慧商城:搜索页面基于商品名称进行搜索,分类页面点击商品进行搜索。(跳转到商品列表页面,地址栏携带的参数作为请求的参数进行请求,然后动态渲染)

基于搜索关键字来进行渲染

笔记中直接 cv 搜索列表静态布局

点击搜索手机就是这样子

组件中没有任何渲染,需要请求参数进行渲染 。

查询参数前两个是关于排序的,目前走的是最短路径,所以只需要关注后面三个。

categoryId:除了进行商品名字跳转到分类页搜索,还能点击分类页中分类的商品跳转到分类页进行搜索

goodsName:基于名称进行搜索

page:分页,如果搜索内容超过一页,右边传入page2,page3

封装接口

在api文件夹下product.js文件中封装请求方法请求商品列表页面请求数据渲染的方法

上节搜索框输入内容搜索,或者点击历史记录进行搜索,将历史记录存入本地之后就跳转到该商品列表页面,并且携带传入搜索列表框中搜索内容。

商品列表页面对地址栏中传递过来的参数进行接收,搜索页是通过查询参数传参,商品列表页面通过query接收,参数名是search

跳转方式有两种 path 和 命名路由, 传参方式有两种 query查询参数传参 和 params传参。 接收参数有两种 query接收和params接收

在分类页点击商品是不传递参数的,或者搜索页面不传递参数只是点击搜索,同样也是不传递参数的

在 创建完成created就发送请求请求数据,发送请求时只传入了商品名称和翻页数量,打印出来可以看到请求的数据

解构出 list ,并且将list中的数据存入准备好的空数组proList中

基于proList对GoodsItem组件进行渲染,然后在该商品列表中通过组件标签引入

此前在首页商品渲染中将商品渲染封装为组件GoodsItem,然后在首页中请求商品数据进行渲染,现在是在商品列表中请求商品数据在该商品列表中进行渲染。

也就是首页和商品列表页面各自请求商品数据在商品组件中进行渲染,然后调用组件标签在自己的页面显示。反正是请求了数据才进行渲染

通过搜索页面传递过来的参数作为商品名称为 发送请求时的参数去请求数据来进行渲染

基于分类页进行渲染

封装接口发请求,获取数据,完成页面渲染,渲染完了加个点击事件

封装分类页面请求

在api文件夹下新建category.js文件封装请求方法

直接笔记中 cv 分类页静态结构

  • 与通过商品名称搜索跳转到商品列表页面一样
  • 点击分类页的商品,也能跳转到商品列表 ,并且点击的商品自动在商品列表地址栏上携带参数categoryId

接下来就应该是商品列表页面接收参数,作为请求中的参数,发送请求,响应回来数据进行渲染

相关推荐
vvilkim1 小时前
全面解析React内存泄漏:原因、解决方案与最佳实践
前端·javascript·react.js
vvilkim1 小时前
React批处理(Batching)更新机制深度解析
前端·javascript·react.js
Bayi·1 小时前
前端面试场景题
开发语言·前端·javascript
程序猿熊跃晖1 小时前
Vue中如何优雅地处理 `<el-dialog>` 的关闭事件
前端·javascript·vue.js
进取星辰2 小时前
12、高阶组件:魔法增幅器——React 19 HOC模式
前端·javascript·react.js
拉不动的猪2 小时前
前端低代码开发
前端·javascript·面试
程序员张32 小时前
Vue3集成sass
前端·css·sass
夜跑者2 小时前
axios 在请求拦截器中设置Content-Type无效问题
前端
知识分享小能手2 小时前
JavaScript学习教程,从入门到精通,Ajax与Node.js Web服务器开发全面指南(24)
开发语言·前端·javascript·学习·ajax·node.js·html5
烛阴2 小时前
Swizzling--OpenGL的向量的灵活组合
前端·webgl