访问包含关键字的 JavaScript 对象属性
Access javascript object properties containing keywords?
我想访问带有关键字的javascript对象属性:
var cloneIndex = $(".clonedInput").length + 1;
$(document).on("click", 'button.clone', function (e) {
e.preventDefault();
$(this).closest(".clonedInput").clone().insertAfter(".clonedInput:last").attr("id",
"clonedInput" + cloneIndex).find("[id], [name] ,[data-valmsg-for]").each(
function () {
this.id = this.id.replace(/'d+$/, cloneIndex);
this.name = this.name.replace(/'d/, cloneIndex);
this.data-valmsg-for = this.data-valmsg-for.replace(/'d/, cloneIndex);
});
cloneIndex++;
});
但因为台词:
this.data-valmsg-for = this.data-valmsg-for.replace(/'d/, cloneIndex);
这有:
this.data-valmsg-for
它抛出一个错误,因为data-valmsg-for中的"for"是一个关键字。另外,当我更改时:
this.data-valmsg-for
自:
this['data-valmsg-for'] = this['data-valmsg-for'].replace(/'d/, cloneIndex);
脚本引发此错误:
Uncaught TypeError: Cannot read property 'replace' of undefined
另外,当我更改时:
this.data-valmsg-for
自:
this.setAttribute('data-valmsg-for',this.getAttribute('data-valmsg-for').replace(/'d/, cloneIndex));
脚本引发此错误:
Uncaught TypeError: Cannot read property 'replace' of null
这是我的 html:
<div id="clonedInput1" class="form-group clonedInput">
<input id="CompanyId1" name="[0].CompanyId" type="hidden" value="">
<label class="control-label col-md-2" for="NationalCode">کد ملی</label>
<div class="col-md-3">
<input class="form-control text-box single-line" data-val="true" data-val-regex="فرمت کد ملی صحیح نمی باشد" data-val-regex-pattern="^[0-9]{10}$" @*data-val-remote="'کد ملی' is invalid." data-val-remote-additionalfields="*.NationalCode,*.initialNationalCode" data-val-remote-url="/Account/IsValidNationalCode"*@ data-val-required="وارد کردن کد ملی اجباریست" id="NationalCode1" name="[0].NationalCode" type="text" value="">
<span class="field-validation-valid text-danger" data-valmsg-for="[0].NationalCode" data-valmsg-replace="true"></span>
</div>
<label class="control-label col-md-2" for="BirthDate">BirthDate</label>
<div class="col-md-3">
<input class="form-control text-box single-line" data-val="true" data-val-date="The field BirthDate must be a date." data-val-required="The BirthDate field is required." id="BirthDate1" name="[0].BirthDate" type="date" value="">
<span class="field-validation-valid text-danger" data-valmsg-for="[0].BirthDate" data-valmsg-replace="true"></span>
</div>
</div>
它抛出一个错误,因为data-valmsg-for中的"for"是一个关键字。
不,它会抛出错误,因为您正在从valmsg
中减去for
this.data
。 this.data-valmsg-for
被解释为this.data - valmsg - for
。
您尝试解决的问题是更新 DOM 元素的数据属性。有多种方法可以做到这一点。最基本的是用getAttribute
读取属性,用setAttribute
设置:
this.setAttribute(
'data-valmsg-for',
this.getAttribute('data-valmsg-for').replace(/'d/, cloneIndex)
);
相关文章:
- 如何从对象的原型方法访问JavaScript对象属性
- 如何将数组项添加到对象属性中
- 设置嵌套对象属性的更好方法
- JavaScript管理具有重复属性名称的对象属性
- 如何使用element.myobj.prop等具有对象属性的元素
- 如何使用(this)访问Angular 2 http rxjs catch函数中的对象属性
- Es6:能够在设置/更新/删除对象属性时调用自定义方法
- 如何在AngularJS工厂中正确声明对象属性
- 如何使用object.assign()从其他对象引用基本对象属性
- 使用XPath样式访问Javascript JSON对象属性
- 将javascript对象(属性+值)合并到一个对象中
- 数组:使对象属性成为数组键
- 无法从JavaScript中的函数调用对象属性
- Google Closure Advanced |无法识别对象属性|动态属性
- Javascript从匿名函数访问外部对象属性
- 从函数更改对象属性
- 如何从字符串变量访问对象属性
- 从嵌套对象属性中获取排除某个值的最高值
- 在Aurelia computeds中,当设置依赖关系时,如何声明对对象属性的依赖关系
- 传递数量不确定的可能嵌套的对象属性