从零玩转系列之微信支付实战PC端装修我的订单页面2

简介: 从零玩转系列之微信支付实战PC端装修我的订单页面

四、装修前端页面

a281d836_5151444.png

可以看到设计图,他的样式和下单页面是一样的只是中间的内容不一样周围的边框和阴影都一样,所以我们可以直接复制下单页面的代码,然后修改一下就可以了

创建我的订单页面

在 views 目录下面创建 order.vue 组合API

5c94693a_5151444.png

新增路由、刷新页面查看

516fa41a_5151444.png

44297240_5151444.png

在分析一下里面的标题也一样啊,所以我们直接复制就行了

2ccde197_5151444.png

效果

f55f0af2_5151444.png

编写数据表格

直接前往https://element-plus.gitee.io/zh-CN/component/table.html官网查看数据表格的使用方法

ba00acb5_5151444.png

看上哪个用哪个直接CV

36401d22_5151444.png

将标签复制到html当中 将参数复制到script当中 刷新页面查看

247da906_5151444.png

c0690696_5151444.png

分页插件

看上哪个用哪个老规矩直接CV 放到 el-table 标签下面 刷新页面查看

258e2f87_5151444.png

ee1b0cd0_5151444.png

总结: 以上我们已经对组件库的功能大致了解了我们直接对接后端数据进行渲染

编写分页查询请求

自己查看自己后端的URl地址

params参数表示路径后面带的参数

data 参数表示传递的JSON数据

18f190ca_5151444.png

编写方法发送请求

复制下面到 order页面

<script setup>
import {onBeforeMount, ref} from "vue";
// ---------------------------------------------------引入API---------------------------------------------------
import orderInfoApi from "@/api/orderInfo";
// ---------------------------------------------------变量---------------------------------------------------
// 我的订单列表
const tableData = ref([])
// 适配移动端
const widthBox = ref(false)
// ---------------------------------------------------方法---------------------------------------------------
// 获取订单列表方法
const getOrderList = () => {
}
// ---------------------------------------------------生命周期---------------------------------------------------
onBeforeMount(() => {
  widthBox.value = window.innerWidth <= 500
  // 获取订单列表
  getOrderList()
})
</script>

完善 getOrderList

思路: 后端请求需要 分页参数 我们需要定义一个请求参数变量用来存储

// 请求参数
const formData = ref({
  pageSize: 10,
  pageNum: 1,
  totalPage: 0,
})

使用 ref 响应式存储那么在使用的时候需要 .value 例如 formData.value 才能拿到数据


修改表格

<!-- 订单列表 -->
      <el-table v-loading="loading" :data="tableData" border style="width: 100%; height: 600px">
        <el-table-column v-if="!widthBox" type="index" width="50"/>
        <el-table-column v-if="!widthBox" prop="orderNo" label="订单编号" width="230"/>
        <el-table-column prop="title" label="订单标题" align="center"/>
        <el-table-column prop="totalFee" label="订单金额" align="center">
          <template #default="scope"> {{ scope.row.totalFee / 100 }} 元</template>
        </el-table-column>
        <el-table-column label="订单状态" align="center"></el-table-column>
        <el-table-column prop="createTime" label="创建时间" align="center"/>
        <el-table-column label="操作" width="70" align="center"></el-table-column>
      </el-table>

介绍 #default=“scope”

在Vue3中,#default="scope"是一种用于处理列表渲染的语法。它允许我们在父组件中定义一个插槽,并通过子组件将数据传递给插槽。这样我们就可以在父组件中使用子组件的数据,并根据需要进行渲染。

重新刷新页面请求成功

09ff5725_5151444.png

编写分页插件

WARNING

我们现在会检查一些不合理的用法,如果发现分页器未显示,可以核对是否违反以下情形:

  • total 和 page-count 必须传一个,不然组件无法判断总页数;优先使用 page-count;
  • 如果传入了 current-page,必须监听 current-page 变更的事件(@update:current-page),否则分页切换不起作用;
  • 如果传入了 page-size,且布局包含 page-size 选择器(即 layout 包含 sizes),必须监听 page-size 变更的事件(@update:page-size),否则分页大小的变化将不起作用。

API#

属性#

属性名 说明 类型 默认值

small 是否使用小型分页样式 boolean false

background 是否为分页按钮添加背景色 boolean false

page-size / v-model:page-size 每页显示条目个数 number —

default-page-size 每页默认的条目个数,不设置时默认为10 number —

total 总条目数 number —

page-count 总页数, total 和 page-count 设置任意一个就可以达到显示页码的功能;如果要支持 page-sizes 的更改,则需要使用 total 属性 number —

pager-count 设置最大页码按钮数。 页码按钮的数量,当总页数超过该值时会折叠 number 7

current-page / v-model:current-page 当前页数 number —

default-current-page 当前页数的默认初始值,不设置时默认为 1 number —

layout 组件布局,子组件名用逗号分隔 string prev, pager, next, jumper, ->, total

page-sizes 每页显示个数选择器的选项设置 object [10, 20, 30, 40, 50, 100]

popper-class 每页显示个数选择器的下拉框类名 string ‘’

prev-text 替代图标显示的上一页文字 string ‘’

prev-icon 上一页的图标, 比 prev-text 优先级更高 string / Component ArrowLeft

next-text 替代图标显示的下一页文字 string ‘’

next-icon 下一页的图标, 比 next-text 优先级更高 string / Component ArrowRight

disabled 是否禁用分页 boolean false

hide-on-single-page 只有一页时是否隐藏 boolean false

事件#

名称 说明 类型

size-change page-size 改变时触发 Function

current-change current-page 改变时触发 Function

prev-click 用户点击上一页按钮改变当前页时触发 Function

next-click 用户点击下一页按钮改变当前页时触发 Function

上面的API属性都有对应的介绍是干啥的那么我们只需用到 当前页数、每页数、和监听分页的点击事件

同学们手动敲一遍吧

1a16529e_5151444.png

页面测试

都有可以正常触发并且调用成功

3e973eaf_5151444.png

3377a023_5151444.png


最后

本期结束咱们下次再见👋~

,关注我不迷路,如果本篇文章对你有所帮助,或者你有什么疑问,欢迎在评论区留言,我一般看到都会回复的。大家点赞支持一下哟~ 💗

【选题思路】

“技术源于生活” 为什么写微信支付这种项目的文章呢? 因为我看到市面上的文章都不全面不细节不小白话更加没有配套Demo!!!

从而我的从零玩转微信支付诞生啦~ 搭配PC端、Uniapp端的不同实现.

【写作提纲】

一、前言

通过前言表达我每次的文章内容是什么东西和注意事项,以及本篇文章的目录和彩蛋

二、介绍

介绍设计图的样式和功能,思路,以及后端接口的编写

三、后端接口制作中

教同学们搭建后端接口,并且测试接口是否正常

四、装修前端页面

介绍设计图当中的样式和功能,并且教同学们如何使用组件库、如何编写请求、如何渲染数据、如何监听事件

以及完成了基本的前后端查询交互

相关文章
|
4月前
|
JSON 小程序 前端开发
微信小程序的目录结构及页面结构的说明
本文详细介绍了微信小程序的目录结构、页面组成部分以及项目的全局配置文件,阐述了小程序的宿主环境和运行机制,包括小程序启动和页面渲染的过程。
微信小程序的目录结构及页面结构的说明
|
5月前
|
小程序
微信小程序多种跳转页面方式
微信小程序多种跳转页面方式
|
3月前
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
569 0
|
4月前
|
小程序 JavaScript API
微信小程序开发学习之页面导航(声明式导航和编程式导航)
这篇文章介绍了微信小程序中页面导航的两种方式:声明式导航和编程式导航,包括如何导航到tabBar页面、非tabBar页面、后退导航,以及如何在导航过程中传递参数和获取传递的参数。
微信小程序开发学习之页面导航(声明式导航和编程式导航)
|
4月前
|
小程序 前端开发 生物认证
微信小程序如何将一个按钮放到页面的最底下?
微信小程序如何将一个按钮放到页面的最底下?
495 5
|
4月前
|
JSON 小程序 JavaScript
微信小程序页面事件,下拉刷新事件和上拉触底事件
这篇文章介绍了微信小程序中如何实现下拉刷新和上拉触底事件,包括开启下拉刷新、配置下拉刷新样式、监听下拉刷新事件,以及监听上拉触底事件和配置上拉触底的距离。
|
5月前
|
小程序 开发者
万能的微信小程序个人主页:商城系统个人主页、外卖系统个人主页、购票系统个人主页等等【全部源代码分享+页面效果展示+直接复制粘贴编译即可】
这篇文章分享了四个不同应用场景下的微信小程序个人主页的源代码和页面效果展示,包括商城系统、外卖系统、医疗挂号和电影购票系统的个人主页。提供了完整的页面布局和样式代码,允许开发者直接复制粘贴并根据自己的项目需求进行简单的改造使用。
万能的微信小程序个人主页:商城系统个人主页、外卖系统个人主页、购票系统个人主页等等【全部源代码分享+页面效果展示+直接复制粘贴编译即可】
|
5月前
|
人工智能 搜索推荐 安全
从零到一:微信机器人开发的实战心得
从零到一:微信机器人开发的实战心得
325 2
|
3月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
783 7
|
3月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
794 1