新建和编辑共用一个页面,怎么实现 用vue2

时间: 2024-02-23 15:59:36 浏览: 30
在Vue2中,可以通过条件渲染来实现新建和编辑共用一个页面。具体实现如下: 1. 首先确定需要保存的数据结构,例如一个包含title和content的对象article。 2. 在组件中定义一个data对象,用于存储需要编辑的数据。初始值可以设置为空对象。 ```javascript data() { return { article: {} } } ``` 3. 在组件的created生命周期钩子中,根据路由参数判断是新建还是编辑操作。如果是编辑操作,向后端API发送请求获取需要编辑的数据,并将返回的数据赋值给data中的article对象。 ```javascript created() { if (this.$route.params.id) { axios.get(`/api/articles/${this.$route.params.id}`) .then(res => { this.article = res.data }) } } ``` 4. 在组件的模板中,根据data中是否有article对象来判断是新建还是编辑状态。如果article对象为空,则显示新建表单,否则显示编辑表单。这里可以使用v-if指令实现条件渲染。 ```html <template> <div> <h1>{{ article.id ? '编辑文章' : '新建文章' }}</h1> <form> <div class="form-group"> <label for="title">标题</label> <input type="text" class="form-control" id="title" v-model="article.title"> </div> <div class="form-group"> <label for="content">内容</label> <textarea class="form-control" id="content" rows="5" v-model="article.content"></textarea> </div> <button type="submit" class="btn btn-primary">{{ article.id ? '保存' : '创建' }}</button> </form> </div> </template> ``` 5. 在提交表单时,根据data中是否有article对象来判断是新建还是编辑操作。如果article对象为空,则向后端API发送创建文章的请求,否则发送更新文章的请求。 ```javascript methods: { submitForm() { if (!this.article.id) { axios.post('/api/articles', this.article) .then(res => { // 新建文章成功,跳转到文章列表页面 this.$router.push('/articles') }) } else { axios.put(`/api/articles/${this.article.id}`, this.article) .then(res => { // 更新文章成功,跳转到文章详情页面 this.$router.push(`/articles/${this.article.id}`) }) } } } ``` 通过以上步骤,就可以实现新建和编辑共用一个页面的功能了。

相关推荐

最新推荐

recommend-type

解决vue多个路由共用一个页面的问题

下面小编就为大家分享一篇解决vue多个路由共用一个页面的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

使用Vue组件实现一个简单弹窗效果

主要介绍了使用Vue组件实现一个简单弹窗效果,本文主要内容会涉及到弹窗遮罩的实现, slot 插槽的使用方式,props 、 $emit 传参,具体组件代码也传上去了。需要的朋友可以参考下
recommend-type

vue页面跳转实现页面缓存操作

打野在A页面野区进行一波骚操作打了一只蓝爸爸,然后点击导航栏跑到B页面的野区秀操作打了一只红爸爸,然后他又回到A野区,希望A野区还是只有一只蓝爸爸被打的状态,其他野没被偷 第一步 在路由里面设置需要缓存的...
recommend-type

在vue中实现嵌套页面(iframe)

主要介绍了在vue中实现嵌套页面(iframe),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Vue拖拽组件列表实现动态页面配置功能

主要介绍了Vue拖拽组件列表实现动态页面配置功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性

![MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性](https://picx.zhimg.com/80/v2-8132d9acfebe1c248865e24dc5445720_1440w.webp?source=1def8aca) # 1. MATLAB结构体基础** MATLAB结构体是一种数据结构,用于存储和组织相关数据。它由一系列域组成,每个域都有一个名称和一个值。结构体提供了对数据的灵活访问和管理,使其成为组织和处理复杂数据集的理想选择。 MATLAB中创建结构体非常简单,使用struct函数即可。例如: ```matlab myStruct
recommend-type

详细描述一下STM32F103C8T6怎么与DHT11连接

STM32F103C8T6可以通过单总线协议与DHT11连接。连接步骤如下: 1. 将DHT11的VCC引脚连接到STM32F103C8T6的5V电源引脚; 2. 将DHT11的GND引脚连接到STM32F103C8T6的GND引脚; 3. 将DHT11的DATA引脚连接到STM32F103C8T6的GPIO引脚,可以选择任一GPIO引脚,需要在程序中配置; 4. 在程序中初始化GPIO引脚,将其设为输出模式,并输出高电平,持续至少18ms,以激活DHT11; 5. 将GPIO引脚设为输入模式,等待DHT11响应,DHT11会先输出一个80us的低电平,然后输出一个80us的高电平,
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。