- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在不同文件中反复要求相同或相似的功能。像下面那样在范围内或范围外要求 Element
会更好吗?
我想它应该在外面,否则我会在我的代码中创建很多 Element 副本,不?
var Element = require("./Element.js")
var _ = function(){
this.element = new Element();
this.stuff;
}
_.prototype.setStuff = function(stuff){
this.stuff = stuff
}
_.prototype.doStuff = function(){
this.stuff();
}
module.exports = _;
谢谢。
最佳答案
由于这是一个 node.js 模块,这里有几个注意事项:
require()
是同步的。因此,您永远不想在实时服务器请求中使用它,因为这会阻止服务器的可扩展性。您通常希望在初始化模块和初始化服务器时使用一次 require()
。
在 node.js 模块中声明的变量仅限于该模块。从技术上讲,模块作用域位于模块函数内部,因此在其中声明的任何变量都已经是局部变量,因此不需要任何额外的作用域保护。
模块被缓存。因此,如果您在同一路径上多次执行 require()
,速度会非常快。在第一次实际加载和初始化模块后,所有后续调用只返回相同的缓存模块句柄。所以,不要试图通过破坏代码结构来减少调用 require()
的地方的数量。编写干净的代码,如果这需要在同一个模块上多次调用 require()
,那没什么大不了的。
requiring the same or similar functions over and over in different files. Would it be better to require Element inside the scope or outside the scope as done so below?
您通常希望将 require()
语句放在 node.js 模块的最高级别,因为您希望在模块首次初始化时将它们初始化一次,并且您希望共享该模块句柄包含模块中的所有代码。如果你的代码足够复杂以至于你想在几个不同的地方为同一个模块调用 require()
来让你的代码更加分区,那么你可能应该将你的代码分解成单独的模块并让每个模块 require()
在任何它自己需要的地方。
I guess it's should be outside, otherwise I will be creating lots of copies of Element all over my code,
在模块的最高范围之外。几乎没有理由不只加载一次模块并与模块中可能想要使用它的所有代码共享模块句柄。
在一些特殊情况下,您可能希望仅在运行时的某些特定条件下仅在需要模块时才动态加载模块。由于加载模块的同步特性,这种情况很少见并且在这样做时会影响性能,因此很少这样做。因此,我不想在我之前的建议中做到绝对,但也想解释一下,仅按需加载内容很少见并且会产生后果。
关于javascript - 需要原型(prototype)内部或外部的功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37235296/
以下代码,我使用 chrome 浏览器控制台进行了检查: function A(){ this.a='a' } 这是一个构造函数。我已经将一个属性 b 赋给了 A 的原型(prototype)。
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 提供事实和引用来回答它. 5年前关闭。 Improve this
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 提供事实和引用来回答它. 3年前关闭。 Improve this
我已经开始阅读 The Pragmatic Programmer,我很喜欢并学习堆形式,但我很难理解示踪子弹和原型(prototype)之间的区别。跟踪项目符号是否像拥有应用程序的所有 View 但尚
尽管阅读了 StackOverflow 上的大多数文章,但我现在实际上对原型(prototype)非常困惑。 function Foo() { } Foo.prototype.speak = func
我正在阅读以下代码,并开始想知道 Rectangle.prototype = Object.create(Shape.prototype) 和 Rectangle.prototype = Shape.
我想知道它们之间的区别: childObj.prototype = Object.create(parentObj.prototype) 和 childObj.prototype = parentOb
这个问题在这里已经有了答案: Why wouldn't I use Child.prototype = Parent.Prototype rather than Child.prototype =
在 node.js 中导出原型(prototype)的首选方法是什么?您可以采用两种方法: 导出原型(prototype)本身 function A () { } module.exports = A
我正在学习 JavaScript,发现了两种分配原型(prototype)的方法。 第一个是A.prototype = B.prototype,第二个是A.prototype = new B() 例如
在一些构造函数的定义之后,例如 child ,我见过以下两种形式: Child.prototype = Parent.prototype; 或 Child.prototype = new Parent
我正在阅读一本关于 OOP javascript 的书,但被其中一个示例卡住了。 在示例代码的第一个版本中,Shape 的一个新实例构造函数被创建并且 toString方法被调用。 toString方
这个问题在这里已经有了答案: What should I connect to the child prototype property in JavaScript (2 个答案) 关闭 8 年前。
在进行原型(prototype)设计时,您在多大程度上放弃了最佳实践来支持代码和修复黑客攻击?当然,代码并不打算在完整的生产环境中保留。 补充:我正在研究一个用 Python 制作的相当大的半工作原型
我正在尝试使用 Prototype 更新隐藏表单字段的值。表单域: 我正在尝试使用原型(prototype)更新值: var additionalVal = ',2'; var itemId = $
我正在阅读How to Make a Javascript Library我发现了作者所说的一个观点: function _() { //Some obects and var
我想用一个新函数扩展“Number”类型,因此我必须定义一个原型(prototype)。当我想到这一点时,我得到了一堆问题: Number 是否既继承了 Object.prototype 又继承了 F
这里好像有区别... 假设我们有 function MyConstructor() {} MyConstructor 的[[Prototype]] 是Function.prototype,不是 MyC
有人建议 Derived.prototype = Object.create(Base.prototype); 优于 Derived.prototype = new Base(); (如 this S
我是一名优秀的程序员,十分优秀!