如何使用element.myobj.prop等具有对象属性的元素
How to use element with object property like element.myobj.prop
如果我声明一个类似的对象
var obj =function(element){
return{
wide:element.clientWidth
}}
我必须像一样申报
var fdiv=new obj(document.etc.etc.);
像一样呼叫
fdiv.wide;
但这相当限制了我的代码。我必须为每个元素声明新的obj。我的问题是,我如何将元素名称设置为动态,以便能够像nodeI_want.obj.wide
或obj.nodeI_want.wide
或类似的任何东西一样使用我的属性和动态给定的节点。注意:clientWidth属性。只是一个例子,说明它将在我的代码中用我自己的属性替换。
您似乎想要扩展HTMLElement
。正确的方法是将您的方法添加到HTMLElement
的prototype
中。
例如(我没有使用你原来的函数代码,因为它试图实现的目标很模糊):
HTMLElement.prototype.getMyWidth = function() {
return this.clientWidth;
};
请参阅HTMLElement
function ElementObj(element){
this.element = element;
this.width = this.element.offsetWidth;
return this;
}
现在你可以做:
var elem1 = new ElementObj(document.getElementById('div1'));
var elem2 = new ElementObj(document.getElementById('div2'));
其中elem1返回对象:
{
element: DOMElement
width: 100
}
相关文章:
- 如何从对象的原型方法访问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中,当设置依赖关系时,如何声明对对象属性的依赖关系
- 传递数量不确定的可能嵌套的对象属性