jjzjj

Prototype

全部标签

javascript - Prototype click、mouseover 和 mouseout 不能一起工作?

我正在尝试做一个非常简单的按钮,它根据鼠标悬停、鼠标移开和单击,我在原型(prototype)中执行此操作,奇怪的是如果我使用mouseover和mouseout,单击按钮后,按钮不会变为白色,似乎是因为鼠标移出,这是我的代码$("izzy").observe('mouseover',function(){$('izzy').setStyle({color:'#FFFFFF'});});$("izzy").observe('mouseout',function(){$('izzy').setStyle({color:'#666666'});});$("izzy").observe('c

javascript - 告诉我的库函数的用户传递的变量类型不正确的最佳方法是什么

我目前正在创建一个javascript函数库。主要供我自己使用,但您永远无法确定其他人是否最终会在他们的项目中使用它,我至少在创建它时就好像那会发生一样。大多数方法只有在传递的变量具有正确的数据类型时才有效。现在我的问题是:提醒用户变量类型不正确的最佳方式是什么?应该抛出这样的错误吗?functionfoo(thisShouldBeAString){//justpretendthatthisisamethodandnotaglobalfunctionif(typeof(thisShouldBeAString)==='string'){throw('foo(var),varshouldb

javascript - 将参数传递给javascript中的原型(prototype)函数

我最近一直在尝试使用javascript进行原型(prototype)设计,但我不明白为什么以下代码不起作用。我想做的是用参数n创建一个新的cheese实例。functionfood(n){this.n=n;}functioncheese(n){alert(this.n);}cheese.prototype=newfood;newcheese('paramesian'); 最佳答案 您正在创建一个新的Cheese实例,并且参数n从未被使用或分配给Cheese实例变量this.n,因为该逻辑仅用于Food构造函数。你可以做几件事:1。

javascript - 你如何从javascript中的子对象调用父对象函数

所以,我正在阅读JohnResig的blog,看到了他的micro-templatingjavascriptengine并决定尝试实现自己的javascript模板管理系统,加深对原型(prototype)继承的理解。然而,在我开始编写它的那一刻,我遇到了一个问题。首先,这是我的基本代码:functiontemplate_manager(){};template_manager.prototype={tags:{},templates:{},output:{},default_template:"default",set:function(tags,template_name){tem

javascript - Javascript 中的构造函数属性是否有好的用例?

首先,这个问题不是“constructor属性的作用是什么?”-关于它到底是什么以及它是如何工作的,有很多很好的文档:它是对创建对象的函数的引用(可能继承自其原型(prototype))。我更有兴趣了解此属性的常见用例。这在理论上似乎一切都很好,但是您什么时候真正需要对构造您的对象的函数的引用?一些想法是:也许我想克隆它。我可以再次调用构造函数并且获取我的对象的另一个实例。这当然不会奏效因为您可能会创建对象的实例原型(prototype),而不是对象本身;再加上一个更受欢迎的方法是创建一个新对象并设置该对象的原型(prototype)。也许你可以用它来弄清楚对象的“类型”是。这看起来很

javascript - CoffeeScript 原型(prototype)错误

这是我正在尝试做的一个例子。User=(name,dob,rank,score)->{name:namedob:dobdetails:{rank:rankscore:score}basicInfo:->return"Name:#{@name}-Dob:#{@dob}-#{@details.rank}"detailedInfo:->return"Name:#{@name}-Rank:#{@details.rank}-Score:#{@details.score}"}User::displayName=->console.log@namebob=newUser("Bob","10/12/6

javascript - 覆盖 Backbone.Collection.prototype.add

是否可以像这样在backbone中全局覆盖collection.add方法:Backbone.Collection.prototype._add=Backbone.Collection.prototype.add;Backbone.Collection.prototype.add=function(models,options){var=newModels=models.items;Backbone.Collection.prototype._add(newModels,options);}我使用的api始终包含下一级集合的实际模型。在items下,我发现自己覆盖了所有集合的.add方

javascript - 只是好奇如何继承 String 对象。 (原型(prototype))

我知道这是不受欢迎的,我只是在探索这个想法,就我的生活而言,似乎无法按照我想要的方式完成这项工作。这个例子应该解释所有:String.prototype.MyNS=function(){}String.prototype.MyNS.fooify=function(){returnthis+'foo!';}vartheString='Kung';alert(theString.MyNS.fooify());当然,这只是将函数定义附加到“foo”……添加this()是行不通的。我知道我在那里失去了背景,但无法弄清楚如何让原件开火并给我我想要的东西。 最佳答案

javascript - JS 实现类似 "extends"的功能(非常简单的继承)

假设我在JS中有一个带有原型(prototype)函数的类...functionFoo(){this.stuff=7;this.otherStuff=5;}Foo.prototype.doSomething=function(){};Foo.prototype.doSomethingElse=function(){};现在说我想通过子类化来“扩展”这个类。在Java中,这看起来像...publicclassBarextendsFoo{}现在我知道在JS中真的没有类的概念,一切都可以改变,这一切都归结为一堆废话字典,但尽管如此,我应该能够复制一个类的原型(prototype)并将其附加到

oop - 是否可以隐藏 Javascript 对象的原型(prototype)!这背后的奥秘是什么?

我正在使用openui5。有一个UI控件Button的构造函数,看不到Button的prototype属性,但是在浏览器控制台中执行时出现了同样的东西!sap.m.Button.prototype.Move=function(){console.log('Move');}varoButton=newsap.m.Button({text:"Hello"});oButton.Move();//throwsundefinedfunction!在控制台中执行浏览器时相同的代码,它有效!jsbin-->http://jsbin.com/tepum/1/edit 最佳答