JavaScript-的含义:var DndUpload=函数(inputElem){};
JavaScript - Meaning of: var DndUpload = function (inputElem){};
我可以要求解释一下吗:
下面的代码代表什么?它是否创建了DndUpload Ojbect?或者,它是否创建了一个DndUpload()函数?我错过的是在JavaScript对象创建过程中通常出现的语句new
。我很困惑,可以请你解释一下吗。
var DndUpload = function (inputElem)
{
this.input = inputElem;
this.dropZone = null;
this.isDragging = false;
this.init();
};
据我所知,这是在Javascript中创建对象的方法:
var myObject = new function()
{
};
如果你与解释有任何联系,那将有所帮助。非常感谢。
这是一种更糟糕的编写方式:
function DndUpload(inputElem)
{
this.input = inputElem;
this.dropZone = null;
this.isDragging = false;
this.init();
}
这是一个函数声明。它不会创建DndUpload
的实例。从技术上讲,它确实创建了一个对象——它的名称是DndUpload
,是Function
的一个实例。创建这个"类:"的实例
var instance = new DndUpload(document.getElementById('someInputId'));
var myObject = new function()
{
};
定义一个匿名构造函数,然后使用匿名构造函数实例化一个新对象。它本可以被var myObject = {}
取代。
var DndUpload = function (inputElem)
{
this.input = inputElem;
this.dropZone = null;
this.isDragging = false;
this.init();
};
定义构造函数(从技术上讲,是指分配给变量的匿名构造函数)。然后,您可以通过使用new
:调用构造函数来创建这个"类"的对象
var dndUploadObject = new DnDUpload(),
anotherUploadObject = new DnDUpload(); //2 unique DnDUpload objects
您所拥有的代码本质上是为一个"类"创建一个构造函数,它或多或少是一个对象的蓝图。
然后,它将该构造函数放入一个名为DndUpload
的变量中
所以你现在可以用制作一个物体
var myObject = new DndUpload(input elem)
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 如何在JavaScript中将字符串转换为函数引用
- 用嵌套函数和默认函数定义函数
- 使用 jQuery 的 .on 函数如何获取事件的原始元素
- 无法导出函数expressjs/requestjs中的变量
- 函数参数中的数据与指定变量之间的任何性能差异
- JQuery合并了keyup和focusout两个函数
- ES6构造函数返回基类的实例
- 监视函数从服务返回不起作用,但作用域函数起作用
- 我可以在json对象中添加一个函数吗
- AngularJS:我可以跳过函数参数回调吗
- 如何使jQuery插件函数可调用以供独立使用,而不在集合上操作
- JavaScript数组排序(函数)用于对表行进行排序,而不是排序
- jquery点击函数select&取消选择
- 拨打'父亲'函数形式a'儿童'ReactJS中的组件
- Node.js v6.2.0类扩展不是函数错误
- 比较从函数和生成的日期对象
- jQuery中是否内置了任何字符串格式化函数
- JavaScript-的含义:var DndUpload=函数(inputElem){};