首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >创建一个具有属性的对象,以反映其输入字段名称并为其赋值

创建一个具有属性的对象,以反映其输入字段名称并为其赋值
EN

Stack Overflow用户
提问于 2019-04-30 19:22:02
回答 1查看 31关注 0票数 0

我有一个带有controlled input fields的React应用程序,目前我在尝试从输入字段名称/路径构建对象并为其赋值时遇到了问题。

假设一个表单生成以下内容的输入:

代码语言:javascript
复制
<input
    type="text"
    name="field_5b55440b965b1[value][1][field_5b554428965b2]"
    placeholder=""
    value="foo"
>

它的名称是:值为foofield_5b55440b965b1[value][1][field_5b554428965b2]

如何从这样的名称=>值对构建对象:

代码语言:javascript
复制
{
    field_5b55440b965b1: {
        value: [
            field_5b554428965b2: '',
            field_5b554428965b2: 'foo',
        ]
    }
}

目前,我的解决方案是使用qs包。我构建的对象是这样的:

代码语言:javascript
复制
$object = qs.parse(`${name}=${value}`, { arrayLimit: 0 });

它在大多数情况下都是成功的:https://runkit.com/embed/pm2ha1inhj3o

但是,如果值中包含& (与符号),则它将失败:https://runkit.com/embed/qeczd27l5xr7

现在,我正在寻找其他可能的解决方案或包。这里有这样的包:

https://www.npmjs.com/package/set-value -但它只允许.(点)路径

https://www.npmjs.com/package/form-serialize -但是您需要表单的DOM,而不是单个输入字段。

希望有人能帮上忙。

致以敬意,

EN

回答 1

Stack Overflow用户

发布于 2019-04-30 20:04:30

为什么不使用一些正则表达式从名称中提取所有级别,然后使用循环遍历列表以生成对象?

代码语言:javascript
复制
var levels = name.match(/regex/);
let $object = {}
let intermediate = $object
for(var i = 0; i < levels.length; i++) {
    intermediate[levels[i]] = (i === levels.length - 1) ? $value : {}
    intermediate = intermediate[levels[i]]
}

抱歉的正则表达式,我不够好,所以我更喜欢让您检查它。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55919831

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档