解决el-input输入框输入数组传参报错

文章目录

一、

该问题是由于JSON规范要求字符串必须使用双引号(")而非单引号(')导致的。

以下是完整的解决方案:

javascript 复制代码
// 转json
const strictParse = input => {
  try {
    // 先尝试标准JSON解析
    return JSON.parse(input)
  } catch {
    try {
      // 二次尝试替换引号
      return JSON.parse(input.replace(/'/g, '"'))
    } catch {
      return input // 返回空数组或抛出错误
    }
  }
}



  // 函数再次赋值
  const fnn = (keyValue) => {
    const parsedArray = strictParse(keyValue)
    // console.log('%c【' + 'parsedArray' + '】打印', 'color:#fff;background:#0f0', parsedArray, typeof parsedArray)
    if (Array.isArray(parsedArray)) {
      // 得到标准数组 ["safe_zone", "node_type"]
      msg.value = parsedArray
    } else if (typeof parsedArray == "object") {
      // 对象
      msg.value = parsedArray
    } else {
      msg.value = keyValue
    }
  }

二、DeepSeek回答

在Vue中使用el-input组件时,当输入数组类型数据出现JSON字符串化问题,可通过以下方案解决:

  1. 使用JSON.parse转换(推荐方案)
javascript 复制代码
<el-input v-model="inputValue" @change="handleInputChange"></el-input>

// 方法处理
const handleInputChange = (value) => {
  try {
    const parsedArray = JSON.parse(value)
    if(Array.isArray(parsedArray)){
      // 得到标准数组 ["safe_zone", "node_type"]
    }
  } catch(e) {
    console.error('解析失败')
  }
}
  1. 自定义双向绑定处理
javascript 复制代码
<el-input 
  :value="JSON.stringify(inputArray)" 
  @input="val => inputArray = parseInput(val)"
></el-input>

// 解析方法
const parseInput = (str) => {
  try {
    return JSON.parse(str)
  } catch {
    return []
  }
}
  1. 使用计算属性中转
javascript 复制代码
const computedArray = computed({
  get: () => JSON.stringify(inputArray),
  set: (val) => {
    try {
      inputArray.value = JSON.parse(val)
    } catch {}
  }
})

关键问题分析:

  • el-input的v-model默认会字符串化数组类型数据
  • 需要手动处理JSON字符串与数组的转换
  • 推荐方案1在保证数据安全性的同时实现需求
相关推荐
灵感__idea4 小时前
Hello 算法:贪心的世界
前端·javascript·算法
killerbasd7 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
橘子编程8 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
叫我一声阿雷吧9 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰9 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong239 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
天若有情67310 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
M ? A11 小时前
Vue 迁移 React 实战:VuReact 一键自动化转换方案
前端·vue.js·经验分享·react.js·开源·自动化·vureact
yuki_uix11 小时前
重排、重绘与合成——浏览器渲染性能的底层逻辑
前端·javascript·面试
Burt11 小时前
我的 2026 全栈选型:Vue3 + Elysia + Bun + AlovaJS
vue.js·全栈·bun