iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue中input被赋值后,无法再修改编辑的问题及解决
  • 247
分享到

Vue中input被赋值后,无法再修改编辑的问题及解决

2024-04-02 19:04:59 247人浏览 独家记忆
摘要

目录input被赋值后,无法再修改编辑我们直入主题方法一方法二Vue综合问题归纳input框赋值后不能进行编辑项目场景问题描述原因分析解决方案input被赋值后,无法再修改编辑 我们

input被赋值后,无法再修改编辑

我们直入主题

上面是我司的业务逻辑图,使用elementui框架,如图,请求数据赋值后,不仅有检测报错信息,而且还有无法修改编辑的问题。

起初以为是我的设置的对象问题,困扰我许久。

后来,翻阅了大佬的文章才了解。

 <el-fORM ref="formInline" :inline="true" :rules="rules" :model="formInline" label-position="right" size="medium">
	<el-form-item label="SIM卡号" prop="icsim">
        <el-input v-model.number="formInline.icsim" maxlength="18" />
    </el-form-item>
    <el-form-item label="ICCID码" prop="iccid">
        <el-input v-model="formInline.iccid" />
    </el-form-item>
    <el-form-item label="激活时间" prop="start">
        <el-date-picker v-model="formInline.start" value-format="yyyy-MM-dd HH:mm:ss" style="width:200px" placeholder="选择日期"/>
    </el-form-item>
    <el-form-item label="服务到期时间" prop="end">
        <el-date-picker v-model="formInline.end" value-format="yyyy-MM-dd HH:mm:ss" style="width:200px" placeholder="选择日期"/>
    </el-form-item>
</el-form>
export default {
  name: 'formInline',
  data () {
    return {
      formInline: {}
    }
  },
  methods: {
    // vue 请求数据
	async getSimData(params) {
      const res = await simInfoByVid(params)
      const { sid, iccid, start, end, storage, icsim, vid } = res.data
      this.formInline.sid = sid
      this.formInline.iccid = iccid
      this.formInline.start = start
      this.formInline.end = end
      this.formInline.storage = storage
      this.formInline.icsim = icsim
      this.formInline.vid = vid
    }
  }
}

上面的代码是我第一次写的代码,使用上面的方法,导致input框或者日期选择框无法再编辑。

根据官方文档定义:如果在实例创建之后添加新的属性到实例上,它不会触发视图更新

根据大佬的文章,总结了两个办法:

方法一

由此Vue实例创建时,formInline的属性名并未声明,因此Vue就无法对属性执行 getter/setter 转化过程,导致formInline属性不是响应式的,因此无法触发视图更新。

解决的方式有两种,第一种就是显示的声明formInline这个对象的属性,如:

data () {
    return {
      formInline: {
      	sid: '',
      	iccid: '', 
      	start: '', 
      	end: '', 
      	storage: '', 
      	icsim: '', 
      	vid: ''
		}
    }

方法二

使用Vue的全局api: $set()赋值:

async getSimData(params) {
      const res = await simInfoByVid(params)
      const { sid, iccid, start, end, storage, icsim, vid } = res.data
      this.$set(this.formInline, 'sid', sid)
      this.$set(this.formInline, 'iccid', iccid)
      this.$set(this.formInline, 'start', start)
      this.$set(this.formInline, 'end', end)
      this.$set(this.formInline, 'storage', storage)
      this.$set(this.formInline, 'icsim', icsim)
    }

vue综合问题归纳input框赋值后不能进行编辑

项目场景

项目场景:前端实现查看编辑功能的时候会出现, input框赋值后input框不能进行编辑,编辑之后自动取消,验证无法进行取消

问题描述

数据代码:

<el-textarea
                  v-model="drawerForm.msg"
                  placeholder="请输入功能描述"
                  :rows="3"
                  allowClear
                ></el-textarea>

js

export default {
  name: 'drawerForm',
  data () {
    return {
      drawerForm: {}
    }
  },
  methods: {
    handleEditHelloForm () {
        // 模拟编辑功能需要数据回显
        this.helloForm.msg = 'hello 我是drawerForm中的msg值'
    }
  }
}

原因分析

  • 空input框进行赋值后,不存在setter和getter方法,导致无法实现双向绑定
  • 由此Vue实例创建时,drawerForm.属性名并未声明,因此Vue就无法对属性执行 getter/setter 转化过程,导致drawerForm属性不是响应式的,因此无法触发视图更新。

解决方案

第一种就是显示的声明drawerForm这个对象的属性,如: 

  data () {
    return {
      drawerForm: {
         msg:""
      }
    }
  },

使用vue的全局方法: this.$set(data, property, value)

data为要修改的对象,property为要添加的属性,value就是这个属性的值    handleEditHelloForm () {
        // 模拟编辑功能需要数据回显
        Vue.set(this.helloForm,'msg', 'hello 我是drawerForm中的msg')
    }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。 

--结束END--

本文标题: Vue中input被赋值后,无法再修改编辑的问题及解决

本文链接: https://www.lsjlt.com/news/147084.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作