详解vue3.0 的 Composition API 的一种使用方法
作者:金色海洋(jyk) 发布时间:2024-04-28 09:23:48
网上讨论的文章已经很多了,这里举一个简单的例子来讨论一下 Composition API 的用法,具体问题才好具体讨论嘛。
假如我们要做一个论坛的讨论列表和分页,以前是把需要的数据都放在data里面,事件都放在methods 里面,代码少的话还好分辨,如果代码多了,看着就头疼了。
现在vue3.0可以按照业务关系分成多个管理类来管理这些代码。
比如帖子列表+发帖功能,我们先做一个模板:
(简单表示一下,不做美化处理了)
<template>
<div>
论坛列表
<div v-for="(item, index) in articleList" :key="'articleList' + index">
{{index}}:{{item.title}}
{{item.viewCount}}
</div>
<div><!--分页-->
<a-pagination v-model:current="acticleCurrent" :total="50" show-less-items />
</div>
</div>
<div style="width:400px">
发个帖子
标题:<a-input v-model:value="articleForm.title"/>
内容:<a-input v-model:value="articleForm.content"/>
<a-button type="dashed" @click="sendArticle" >发表帖子</a-button>
</div>
</template>
上面的模板部分没有啥区别,变化部分在js代码。
我们可以先写一个帖子列表的管理类,包含帖子列表的数据,和依据页号加载数据的方法。
代码如下:
// 帖子列表的管理类
const manageArticleList = () => {
const articleList = ref([
{
title: '这是帖子',
viewCount: 100,
sendTime: '2020-10-20'
}
])
// 依据页号加载帖子列表
const loagActicleListByPage = (pageIndex) => {
// alert(pageIndex)
articleList.value = [
{
title: '这是新加载的帖子帖子',
viewCount: 100 + parseInt(pageIndex),
sendTime: '2020-10-20'
}
]
}
return {
articleList,
loagActicleListByPage
}
}
再写一个分页的管理类(使用antdv的a-pagination),代码如下
// 分页管理类
const manageActiclePage = () => {
const acticleCurrent = ref(0)
return {
acticleCurrent
}
}
最后我们可以在setup里面把这两个管理类给结合起来,一起返回给view。
export default {
setup () {
// 引入查询管理
const { articleList, loagActicleListByPage } = manageArticleList()
// 引入分页管理
const { acticleCurrent } = manageActiclePage()
// 监听页号变化,加载数据
watch(acticleCurrent, (newValue, oldValue) => {
loagActicleListByPage(newValue)
})
// 返回给view
return {
articleList,
acticleCurrent,
}
}
}
在setup里面,监听 acticleCurrent 页号变化,调用 manageArticleList 的 loagActicleListByPage 事件,加载数据。
当然也可以有其他的组合方式,这里只是举个简单的例子。
这样代码可以根据业务逻辑分散开,便于扩展和维护,比如我们要加一个查询功能,那么可以在 manageArticleList 里面加个 loagActicleListByQuery 的事件。
最后的效果就是,代码依据业务逻辑,完全分散成多个管理类,setup只需要负责加载和整合即可,setup里面也不会有很多代码。
管理类应该可以写在单独的js文件里面,比如我们把表单的js代码写在单独的js文件里面:(bbs-manageArticleForm.js)
import { ref } from 'vue'
// 帖子列表的管理类
export function manageArticleForm () {
const modelForm = ref(
{
title: '这是帖子标题',
content: '帖子内容',
sendTime: '2020-10-20'
}
)
// 依据页号加载帖子列表
const sendArticle = () => {
// 调用axios 向后端提交
alert('假装发表成功了。。。')
}
return {
articleForm: modelForm,
sendArticle
}
}
然后在views里面用import引入
import { manageArticleForm } from './bbs-manageArticleForm.js'
在setup里面设置如下:
setup() {
......
// 表单
const { articleForm, sendArticle } = manageArticleForm()
// 返回给view
return {
......
articleForm,
sendArticle,
......
}
}
写在单独的js文件里面,意味着可以复用。不仅这里可以用,其他的地方也可以直接拿过来用。好吧,这个表单基本没啥可以好复用的,这里只是举个例子。
来源:https://www.cnblogs.com/jyk/p/13877289.html


猜你喜欢
- 问题:用pycharm每次修改代码后第一次运行还是原来的结果,运行第二次的时候才是修改后代码的结果解决:每次修改代码后保存一下即可解决补充:
- 1.前言前面学完了SQL Server的基本语法,接下来学习如何在程序中使用sql,毕竟不能在程序中使用的话,实用性就不那么大了。2.最基本
- 0、背景shutil.move可以实现文件或者目录的移动。打印:import shutilhelp(shutil.move)# 打印如下:&
- 前言通过pandas的使用,我们经常要交互式地展示表格(dataframe)、分析表格。而表格的格式就显得尤为重要了,因为大部分时候如果我们
- 1. argparse 模块简介argparse是一个用来解析命令行参数的 Python 库,它是 Python 标准库的一部分。基于 py
- 最近老板叫做一个数据查重的小练习,涉及从一个包含中文字段的文件中提取出其中的中文字段并存储,使用php开发。中间涉及到php正则表达式中文匹
- 开发过程中,错误免不了。为了纠正错误与规范化。可以使用MS SQL Server的系统存储过程sp_rename与OBJECTPROPERT
- mysql查询字段为null的数据navicat查询数据为null的数据varchar字段 默认为(null)所以查询的语句是se
- 一、构建示例数据import pandas as pdimport numpy as npdata = {"ID":[2
- 在Web标准中一个很重要的概念就是强调页面的结构与表现分离。说的通俗一点就是XHTML中应该没有样式化的东西,而且Web在浏览器中除内容外都
- 使用mysql主从复制的好处有:1、采用主从服务器这种架构,稳定性得以提升。如果主服务器发生故障,我们可以使用从服务器来提供服务。2、在主从
- 微博热搜的爬取较为简单,我只是用了lxml和requests两个库url= https://s.weibo.com/top/summary?
- 开发时,通常打开Debug模式会快速定位开发时的一些问题。项目开始部署时,关闭Debug模式,url.py路由静态文件和图片写法:# url
- 1. 多线程的作用简而言之,多线程是并行处理相互独立的子任务,从而大幅度提高整个任务的效率。2. Python中的多线程相关模块和方法Pyt
- 本文实例为大家分享了vue动态控制el-table表格列的展示与隐藏的具体代码,供大家参考,具体内容如下1.引入el-table组件,这里我
- 本文web服务器使用的为apache。1. 安装apacheyum install -y httpd2. 配置apache修改apache配
- 本文实例讲述了Python基于list的append和pop方法实现堆栈与队列功能。分享给大家供大家参考,具体如下:#coding=utf8
- 如下所示:import numpy as npa = np.array([[1,2,3],[4,5,6],[7,8,9]])b = np.a
- 现在我们已经很熟悉Django的MTV模式了。模板(template)负责如何去展示数据,而视图(view)负责筛选出正确的数据。因此通常来
- 1. 前言之前提到过目前我们的进程都是通过supervisor(http://supervisord.org/)这样一个进程管理软件进行管理